PHP 获取二维数据的某个列全部数据使用array_column 和 用foreach 处理的性能对比

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 列

猜你喜欢

转载自blog.csdn.net/m0_37752860/article/details/115353045