JavaScript の配列ソート比較関数にはブール値の戻り値で十分ですか?
Dec 16, 2024 am 05:54 AMJavaScript での並べ替え: 比較関数にはブール値を返すだけで十分ですか?
この質問は、配列を単純に並べ替えるだけであるというよくある誤解から生じています。比較関数でブール値 (true または false) を返すだけで十分です。このアプローチは場合によっては機能しているように見えますが、これは正しくなく、予測できないソート結果を引き起こす可能性があります。
ブール値を返すだけでは不十分な理由
ソートにおける比較関数は、配列内の 2 つの要素の相対的な順序を決定することです。正しく一貫した並べ替えを行うには、比較関数は順序を示す数値を返す必要があります:
- 0: 要素は同等であり、順序付けにおいて交換可能であると見なすことができます (例: [1, 1] は変更されません)。
- 正の数: 最初の要素 (a) が大きいとみなされます。
- 負の数: 最初の要素は 2 番目の要素より小さいとみなされ、並べ替えられた配列では前に来る必要があります。
ブール値 (true または false) を返すだけでは、この情報は正確に伝わりません。たとえば、ブール値 true は要素が等しいことを意味しますが、a を b に先行させるか、その逆にするかは指定しません。
ブール比較関数を使用した結果
ブール値のみを返す比較関数を使用すると、未定義または予期しない並べ替え動作が発生する可能性があります。並べ替えの実装が異なると、結果の解釈が異なる場合があり、ブラウザーや環境間で不一致が生じる可能性があります。
たとえば、次のコードは配列を意図したとおりに並べ替えられない可能性があります。
arr = [1, 0, 2]; arr.sort((a, b) => a > b); // Returns a boolean console.log(arr); // Output: [0, 1, 2] or [1, 0, 2] (depending on browser/environment)
この場合、 Chrome と Internet Explorer 11 は > を解釈します。 b を a >= b として計算すると、[0, 1, 2] になります。ただし、Opera 12 はこれを単に > として解釈します。 b、結果は [1, 0, 2] になります。
正しい比較関数の実装
正しく一貫した並べ替えを保証するには、次のような比較関数を定義することが不可欠です。適切な数値を返します:
- 数値の場合は、単純に 2 つの要素の差を返します: (a - b).
- 文字列または他の同等の型の場合は、「より大きい」、「等しい」、または「より小さい」をそれぞれ示す 1、0、または -1 を返します。
- 複雑なオブジェクト タイプの場合は、関連するオブジェクトを取得して比較するカスタム比較関数を使用します。プロパティ。
結論
JavaScript で並べ替えるための比較関数でブール値を返すことは、一部のシナリオでは機能するように見える場合がありますが、これは意図した方法ではなく、予測できない結果につながる可能性があります。正しい実装を使用することで、開発者はブラウザや環境に関係なく、配列を確実に希望の順序で並べ替えることができます。
以上がJavaScript の配列ソート比較関数にはブール値の戻り値で十分ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

人気の記事

人気の記事

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









