大家可能都用過in_array來判斷一個數據是否在一個數組中,一般我們的數組可能數據都比較小,對性能沒什麼影響,所以也就不會太在意,但是如果數組比較大的時候,性能就會下降,運行的就會久一點,那如果針對在大數組情況下做優化呢,下面說兩種方法(都是通過自定義函數來實現):
1.數組key與value翻轉,通過isset判斷key是否存在於數組中
/** * in_array is too slow when array is large */public static function inArray($item, $array) { $flipArray = array_flip($array); return isset($flipArray[$item]); }
大家可能也會問爲什麼不用 array_key_exists 來做判斷二用isset呢? 下面看下array_key_exists() 與 isset() 的對比:
isset()對於數組中爲NULL的值不會返回TRUE,而array_key_exists()會。
<?php$search_array = array('first' => null, 'second' => 4);// returns falseisset($search_array['first']);// returns truearray_key_exists('first', $search_array);?>
2.用implode連接,直接用strpos判斷
用implode函數+逗號連起來,直接用strpos判斷。php裏面字符串取位置速度非常快,尤其是在大數據量的情況下。不過需要注意的是首尾都要加”,” ,這樣比較嚴謹。如: ,user1,user2,user3, 查找的時候,查,user1,。還有strpos要用!== false,因爲第一個會返回0。示例如下:
/** * in_array is too slow when array is large */public static function inArray($item, $array) { $str = implode(',', $array); $str = ',' . $str . ','; $item = ',' . $item . ','; return false !== strpos($item, $str) ? true : false; }