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

浙公网安备 33010602011771号