偶然看到一个面试题说怎么优化 in_array在大数组的场景下的性能问题 然后在网上找答案, 都介绍说用 array_flip 反转数组的键值对, 然后用isset 和 array_key_exists能够处理这个场景, 下面用代码来试试实际情况是不是这样的.
测试PHP 版本: PHP 7.4.9 (cli) (built: Aug 7 2020 19:22:27) ( NTS )
先准备一个 9999 长度的随机大数组
然后上测试代码 循环 1w 次
$largeArr = require 'arr.php';
$start = microtime_float();
for ($i = 0; $i < 100000; $i++) {
in_array('5fe1aabd44607', $largeArr);
}
$end = microtime_float();
$finished = $end - $start;
echo "in_array 耗时{$finished}\r\n";
执行结果是: in_array 耗时28.178212881088
确实很耗时间
array_key_exists的执行代码
//array_flip 耗时0.00046610832214355
$flipArr = array_flip($largeArr);
$start = microtime_float();
for ($i = 0; $i < 100000; $i++) {
array_key_exists('5fe1aabd44607', $largeArr);
}
$end = microtime_float();
$finished = $end - $start;
echo "array_key_exists 耗时{$finished}\r\n";
执行结果: array_key_exists 耗时0.0029549598693848
最后是 isset (判断有值并且这个值不能是 null 才会返回 true)
$start = microtime_float();
for ($i = 0; $i < 100000; $i++) {
isset($flipArr['5fe1aabd44607']);
}
$end = microtime_float();
$finished = $end - $start;
echo "isset 耗时{$finished}\r\n";
执行结果是: isset 耗时0.0027499198913574
执行结果出来确实比 in_array 速度快, 而且 array_flip 速度很快