Loading

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 列

posted @ 2021-03-31 16:04  天才大野狼  阅读(177)  评论(1)    收藏  举报