JavaScript ES6 のキー付きコレクション: 計算/時間の複雑さ
ES6 仕様では、キー付きコレクション (Set、Map、WeakSet、WeakMap) を提供しています。特定の計算量/時間の複雑さが保証されます。これらのコレクションは、コレクション内の要素の数に比例して、平均でサブリニアなアクセス時間を要求する監視可能なセマンティクスを実装しています。
仕様では特定のアルゴリズムを要求していませんが、実装ではパフォーマンスの高いアルゴリズムを使用することが推奨されています。それにも関わらず、この仕様では Set.prototype.has、add、delete などの操作に定時アクセス (O(1)) を明示的に要求していません。
仕様自体から重要な説明が得られ、次のように述べられています。 Keyed Collections 仕様で使用されるデータ構造は、特定の実装モデルではなく、必要な観察可能なセマンティクスを記述することのみを目的としています。これにより、実装でハッシュ テーブルや同様の構造を使用して定常的なアクセスを実現する可能性が残されます。
要約すると、ES6 仕様ではキー付きコレクションの O(1) 時間計算量を厳密に義務付けていませんが、実装を強く推奨しています。パフォーマンスの高いアルゴリズムを使用します。その結果、ほとんどの実装は、平均して一定のアクセス時間を提供するように設計されています。
以上がJavascript ES6 におけるキー付きコレクションの計算量/時間の保証は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。