但是如果數組比較大的時候,效能就會下降,啟動並執行就會久一點,那如果針對在大數組情況下做最佳化呢,下面說兩種方法(都是通過自訂函數來實現):
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()會。
代碼如下:
$search_array = array('first' => null, 'second' => 4);
// returns false
isset($search_array['first']);
// returns true
array_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;
}
http://www.bkjia.com/PHPjc/751221.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/751221.htmlTechArticle但是如果數組比較大的時候,效能就會下降,啟動並執行就會久一點,那如果針對在大數組情況下做最佳化呢,下面說兩種方法(都是通過自訂函...