大家可能都用过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]);
}
* 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, ‘seco来源gao.dai.ma.com搞@代*码网nd’ => 4);
$search_array = array(‘first’ => null, ‘seco来源gao.dai.ma.com搞@代*码网nd’ => 4);
// returns false
isset($search_array[‘first’]);
// returns true
array_key_exists(‘first’, $search_array);
?>
以上就是2个自定义的PHP in_array 函数,解决大量数据判断in_array的效率问题的详细内容,更多请关注gaodaima搞代码网其它相关文章!