in_array大数组查询性能问题
最近在实现一个项目接口的时候发现当数组过大的时候,数据返回的速度有点慢。接口数据返回最长反应时间2s,经过反复调试发现代码段耗时最长的部分在in_array()
函数。
解决过程
在*找到了一篇提供我解决思路的文章
- which is faster, array_key_exists or array_search?
文中说到:
array_key_exists
is much faster.array_search
must traverse the whole array, so it is O(n).array_key_exists
is a hash table lookup, so it is O(1).
----分割线----
I think it’s faster for PHP to check for keys (
array_key_exists()
or simplyisset($array[$key]))
. To search for a value, PHP must cycle through the array; to search for a key PHP will use a hash function.
该数组是用来保存用户账号,一直不销毁存储在内存。
原数组 $array=array('account1','account2','$account3');
修改后的数组 $array=array('account1'=>0,'account2'=>0,'$account3'=>0)
使用isset($array[$account]))
来检测账号是否存在该数组内
总结
由于in_array()
函数对数组进行遍历查询,O(n),随n(数组长度)的增大耗时将增加。所以在对大数组使用in_array()
函数应考虑效率问题。
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });当面对大数组查询的时候,在PHP中应该尽量采用key查询而不是value查询。
以上就介绍了in_array大数组查询性能问题,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。
推荐阅读
-
关于Java数组查询的相关问题及实例 原创
-
关于Java数组查询的相关问题及实例 原创
-
MySQL 删除大表的性能问题解决方案
-
一个mysql数据库查询性能的问题_MySQL
-
遭遇php的in_array低性能问题
-
SQLServer访问Oracle查询性能问题解决
-
php中使用in_array() foreach array_search() 查找数组是否包含时的性能对比_PHP
-
php 查询sql 输出的数组问题求助
-
。还得接着。关于PHP中怎么把数组作为sql查询语句的条件,小弟我的代码有有关问题
-
php中使用in_array() foreach array_search() 查找数组是否包含时的性能对比,phpforeach二维数组_PHP教程