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

本文通过测试脚本对比了PHP中array_column函数与foreach循环在处理二维数组获取特定列数据时的性能差异。结果显示,array_column在处理10万条数据时平均只需6ms,而foreach平均需要22ms,性能差距接近4倍。测试旨在探究并记录这两种方法在大数据量处理时的效率差异。
摘要由CSDN通过智能技术生成

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 列

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP 中,可以使用 `array_multisort()` 或 `usort()` 函数来对二维数组进行排序。 `array_multisort()` 函数可以同时对多个数组或多维数组进行排序,并且可以指定升序或降序。以下是一个随机排序的示例: ```php // 定义二维数组 $people = array( array('name' => 'Tom', 'age' => 20), array('name' => 'John', 'age' => 25), array('name' => 'Mary', 'age' => 18), array('name' => 'Peter', 'age' => 30) ); // 获取年龄作为排序依据 foreach ($people as $key => $row) { $age[$key] = $row['age']; } // 使用 $age 数组对 $people 数组进行排序 array_multisort($age, SORT_DESC, $people); // 输出排序结果 print_r($people); ``` 上述示例中,我们首先使用 `foreach` 循环遍历 `$people` 数组,获取其中的年龄作为排序依据,并将其存储到 `$age` 数组中。然后,使用 `array_multisort()` 函数对 `$people` 数组进行排序,排序规则为按照年龄降序排。最后,输出排序后的结果。 另外,也可以使用 `usort()` 函数对二维数组进行排序,该函数需要自定义排序函数。以下是一个随机排序的示例: ```php // 定义二维数组 $people = array( array('name' => 'Tom', 'age' => 20), array('name' => 'John', 'age' => 25), array('name' => 'Mary', 'age' => 18), array('name' => 'Peter', 'age' => 30) ); // 自定义随机排序函数 function randomSort($a, $b) { return rand(-1, 1); } // 使用 usort() 函数对 $people 数组进行排序 usort($people, 'randomSort'); // 输出排序结果 print_r($people); ``` 上述示例中,我们首先定义了一个自定义的排序函数 `randomSort()`,该函数返回 -1、0 或 1 中的一个随机值。然后,使用 `usort()` 函数对 `$people` 数组进行排序,排序规则为按照 `randomSort()` 函数的返回值进行排序。最后,输出排序后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值