PHP 获取二维数据的某个列全部数据使用array_column 和 用foreach 处理的性能对比
今天看见同事的代码中有一处取二维数组中某一个列的方法, 看到是使用foreach 来处理的.
我想,如果是我的话肯定会使用 array_column 来处理, 但是这两个性能究竟差多少不清楚, 只是知道, PHP 内置函数肯定处理的比较快, 快多少也没有谱.
遂决定写了个简单的脚本测试一下性能.
测试完毕 发现 foreach 在处理10w 数据平均用时 22ms (肯定和机器配置有关), 但是 array_column 处理只需要 6ms, 相差快4倍, 虽然感觉没有什么用, 但是还是记录一下,满足一下偶尔的好奇心.
下面是我的测试流程和测试脚本.
<?php
$test_array = [];
//生成一个10w 的数组
for($i = 0; $i < 100000; $i++) {
$push_arra = [
'id' => $i,
'rand' => mt_rand(1000,9999).mt_rand(1000,9999).mt_rand(1000,9999),
];
$test_array[] = $push_arra;
}
$file = fopen("./max_array.php","w");
$str = "<?php" . PHP_EOL . "\$max_array = " . var_export($test_array, true) . ";";
fwrite($file, $str);
fclose($file);
以上的文件会生成一个 max_array.php , 里面会有一个 $max_array 的数组, 有10w 个
<?php
require_once "./max_array.php";
$php_time_start= microtime(true);
//foreach($max_array as $key => $value) {
// $_category_ids []= $value[ 'rand' ];
//}
$_category_ids = array_column($max_array, "rand");
$php_time_end= microtime(true);
$php_time= $php_time_end - $php_time_start;
$php_time = $php_time * (pow(10,6));
echo"这个脚本执行的时间为$php_time us" . PHP_EOL;
这个脚本记录下array_column 和 foreach 取这个大数组 中 的rand 列