ただし、配列が比較的大きい場合、パフォーマンスが低下し、実行時間が長くなります。そのため、大規模な配列を最適化する場合は、次の 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