ホームページ > 記事 > ウェブフロントエンド > プロパティの一致に基づいて配列からオブジェクトを効率的に削除するにはどうすればよいですか?
プロパティ マッチングによる配列からのオブジェクトの効率的な削除
プロパティ値に基づいて配列からオブジェクトを選択的に削除するには、次のことを避けることが重要です削除中の配列の長さの変更に関する潜在的な問題。以下に 2 つの効果的な方法を示します。
方法 1: ループ カウンターをデクリメントする
スプライスを使用してオブジェクトを削除している場合、削除のたびに配列の長さが減少し、潜在的に先頭に立つ可能性があります。ループ内で不正な動作が発生する可能性があります。これに対処するには、オブジェクトが削除されるたびにループ カウンタ (i) を 1 ずつ減らします。
方法 2: 保持要素を上書きする
保持したい要素を上書きする反復中に、線形時間の削除を回避し、配列のサイズをより効率的に変更できます。最後に保持された要素のインデックスを追跡するには、end のような変数を使用し、そのインデックスで配列内の要素を単純に上書きします。
現代の実践: ハッシュ セット
最新のランタイムでは、ハッシュ セットを活用して、ルックアップをさらに効率的に実行できます。削除したいオブジェクトのプロパティのリストから Set を作成することで、一定時間内に不要なオブジェクトを除外できます。
汎用インプレース フィルタリング関数
コードの再利用性をさらに向上させるには、配列のインプレース フィルタリング用の汎用関数を作成することを検討してください。この関数 filterInPlace は、配列とフィルタリング ロジックを定義する述語関数を受け入れます。オブジェクトを効率的に削除するために、上で概説したのと同じ原則に従います。
以上がプロパティの一致に基づいて配列からオブジェクトを効率的に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。