Heim >Backend-Entwicklung >PHP-Tutorial >in_array和array_keys哪个效率更快

in_array和array_keys哪个效率更快

WBOY
WBOYOriginal
2016-06-23 14:14:481378Durchsuche

判断一个百万级别的数值数组中是否存在对应的值,如题.求教!


回复讨论(解决方案)

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一下就知道是否存在了

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

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn