热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

in_array和array_keys哪个效率更快

in_array和array_keys哪个效率更快
判断一个百万级别的数值数组中是否存在对应的值,如题.求教!


回复讨论(解决方案)

in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值

in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值
后者可以有重复值的吧,返回一个数组,我做过测试可以有相同的值。


in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值
后者可以有重复值的吧,返回一个数组,我做过测试可以有相同的值。

你试试,可以的话向官网报bug


in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值
后者可以有重复值的吧,返回一个数组,我做过测试可以有相同的值。

key哪里来的重复值???



in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值
后者可以有重复值的吧,返回一个数组,我做过测试可以有相同的值。

你试试,可以的话向官网报bug


哈哈哈 你太搞了...



in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值
后者可以有重复值的吧,返回一个数组,我做过测试可以有相同的值。

你试试,可以的话向官网报bug
这个是真可以的,我昨天刚测试过,这个数组如果不是键值数组的话返回的是数值数组的索引,而且该函数返回的是一个数组,如果不可能又重复值那么只有一个值的话为什么要返回一个数组呢?

它的第二个参数是可选择的,如果空着会返回所有键名组成的数组。如果指定,如你的需求,它只会返回对应的一个键名。

楼主,你的需求,使用这个方法解决是否合适?

楼主,你的需求,使用这个方法解决是否合适?
我也觉得不合适,不过暂时没想到更合适的方法.

你做什么业务啊,全放到数组中,占用内存,还不如在数据库中捞取你要的

1楼大神说的是对的
in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值

小菜补充一下,如果数组中有重复的键值,那么按键-值方式取时,得到的是最后的那个键对应的值,但是用array_keys取键时返回的是第一次出现的键。

另外,这么大的数据量的话完全可以放在memcache这样的nosql里了,速度够快,对你的需求也完全满足,get一下就知道是否存在了

1楼大神说的是对的
in_array 是顺序查找
array_keys 是查哈希表
当然是后者快,但后者不可能有重复值

小菜补充一下,如果数组中有重复的键值,那么按键-值方式取时,得到的是最后的那个键对应的值,但是用array_keys取键时返回的是第一次出现的键。

另外,这么大的数据量的话完全可以放在memcache这样的nosql里了,速度够快,对你的需求也完全满足,get一下就知道是否存在了

他这个可能是纯技术流方案 并不是实际应用解决方案 所以大家别太操心

推荐阅读
author-avatar
风信子的春天R
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有