找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1292|回复: 0
打印 上一主题 下一主题

2个自定义的PHP in_array 函数,解决大量数据判断in_array的效率问题

[复制链接]

2617

主题

2617

帖子

7789

积分

论坛元老

Rank: 8Rank: 8

积分
7789
跳转到指定楼层
楼主
发表于 2018-2-14 05:59:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            但是如果数组比较大的时候,性能就会下降,运行的就会久一点,那如果针对在大数组情况下做优化呢,下面说两种方法(都是通过自定义函数来实现):
1.数组key与value翻转,通过isset判断key是否存在于数组中
[U]复制代码[/U] 代码如下:
/**
* 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()会。
[U]复制代码[/U] 代码如下: 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。示例如下:
[U]复制代码[/U] 代码如下:/**
* 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;
}
            
            
您可能感兴趣的文章:
  • asp和php下textarea提交大量数据发生丢失的解决方法
  • phpmyadmin里面导入sql语句格式的大量数据的方法
  • PHP查询MySQL大量数据的时候内存占用分析
  • phpExcel导出大量数据出现内存溢出错误的解决方法
  • php 表单提交大量数据发生丢失的解决方法
  • php导入大量数据到mysql性能优化技巧
  • php查询mysql大量数据造成内存不足的解决方法
  • php post大量数据时发现数据丢失问题解决方法
  • 解决PHP里大量数据循环时内存耗尽的方法
  • PHP查询大量数据内存耗尽问题的解决方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端