ホームページ > バックエンド開発 > PHPチュートリアル > 大量のデータから in_array を判断する効率の問題を解決する 2 つのカスタマイズされた PHP in_array 関数_PHP チュートリアル

大量のデータから in_array を判断する効率の問題を解決する 2 つのカスタマイズされた PHP in_array 関数_PHP チュートリアル

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-07-13 10:34:34
オリジナル
945 人が閲覧しました

ただし、配列が比較的大きい場合、パフォーマンスが低下し、実行時間が長くなります。そのため、大規模な配列を最適化する場合は、次の 2 つの方法があります (どちらもカス​​タム関数を使用して実装されます)。

1. 配列のキーと値を反転し、isset を使用して配列にキーが存在するかどうかを確認します

コードは次のとおりです:

/**

* 配列が大きい場合、in_array は遅すぎます

 */

パブリック静的関数 inArray($item, $array) {

$flipArray = array_flip($array);

return isset($flipArray[$item]);

}

なぜ isset を使用する代わりに array_key_exists を判断に使用しないのかと疑問に思うかもしれません。 array_key_exists() と isset() の比較を見てみましょう:

isset() は配列内の NULL 値に対して TRUE を返しませんが、array_key_exists() は返します。

コードは次のとおりです:

$search_array = array('first' => null, ' Second' => 4);

// false を返します

isset($search_array['first']);

// true を返します

array_key_exists('first', $search_array);

?>

2. implode を使用して接続し、strpos を使用して直接判断します

implode関数+カンマで接続し、strposで直接判定します。 PHP の文字列位置は、特にデータ量が多い場合に非常に高速です。ただし、先頭と末尾に「,」を付けるとより厳密になりますので注意が必要です。例: ,user1,user2,user3、検索する場合は、,user1, を検索します。最初のものは 0 を返すため、strpos! == false も使用します。例は次のとおりです:

コードは次のとおりです:/**

* 配列が大きい場合、in_array は遅すぎます

 */

パブリック静的関数 inArray($item, $array) {

$str = implode(',', $array);

$str = ',' . $str .

$item = ',' .$item .

false を返す !== strpos($item, $str) ? true : false;

}

http://www.bkjia.com/PHPjc/751221.html

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/751221.html技術記事ただし、配列が比較的大きい場合、パフォーマンスが低下し、実行時間が長くなります。そのため、大規模な配列を最適化する場合は、次の 2 つの方法があります (どちらもカス​​タム関数を使用します... )。
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート