2个自定义的PHP in_array 函数,解决大量数据判断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 false
isset($search_array['first']);

// returns true
array_key_exists('first',$search_array);
?>


2.用implode连接,直接用strpos判断

用implode函数+逗号连起来,直接用strpos判断。PHP里面字符串取位置速度非常快,尤其是在大数据量的情况下。不过需要注意的是首尾都要加”,”,这样比较严谨。如:,user1,user2,user3,查找的时候,查,。还有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;
}

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...