PHP中二维数组排序 usort 和 array_multisort 的使用和性能比较

usort 和 array_multisort 的使用

function test()
{
    $data = [
        ['name' => '张三', 'sort' => 60],
        ['name' => '李四', 'sort' => 50],
        ['name' => '王五', 'sort' => 80],
    ];

    // 一、按照sort字段顺序排序
    // 1、usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] > $b['sort'] ? 1 : -1;
    });

    // 2、array_multisort
    array_multisort(array_column($data, 'sort'), SORT_ASC, $data);

    // 二、按照sort字段倒序排序
    // 1、usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] < $b['sort'] ? 1 : -1;
    });

    // 2、array_multisort
    array_multisort(array_column($data, 'sort'), SORT_DESC, $data);
}

usort 和 array_multisort性能测试

1、1000数据量

function test()
{
    $data = [];
    for ($i = 1; $i <= 1000; $i++) {
        $data[] = ['sort' => mt_rand(1, 100000000)];
    }

    $startTime = microtime(true);

    // 测试usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] < $b['sort'] ? 1 : -1;
    });

    // 测试array_multisort
//    array_multisort(array_column($data, 'sort'), SORT_DESC, $data);

    $endTime = microtime(true);
    $subTime = $endTime - $startTime;

    echo $subTime;exit;
}

测试结果:
usort :0.0015461444854736 波动范围在 0.001 ~ 0.002
array_multisort:0.00037407875061035 波动范围在 0.0002 ~ 0.0004

2、10000数据量

function test()
{
    $data = [];
    for ($i = 1; $i <= 10000; $i++) {
        $data[] = ['sort' => mt_rand(1, 100000000)];
    }

    $startTime = microtime(true);

    // 测试usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] < $b['sort'] ? 1 : -1;
    });

    // 测试array_multisort
//    array_multisort(array_column($data, 'sort'), SORT_DESC, $data);

    $endTime = microtime(true);
    $subTime = $endTime - $startTime;

    echo $subTime;exit;
}

测试结果:
usort :0.021894931793213 波动范围在 0.020 ~ 0.023
array_multisort:0.0053129196166992 波动范围在 0.0036 ~ 0.0078

3、100000数据量

function test()
{
    $data = [];
    for ($i = 1; $i <= 100000; $i++) {
        $data[] = ['sort' => mt_rand(1, 100000000)];
    }

    $startTime = microtime(true);

    // 测试usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] < $b['sort'] ? 1 : -1;
    });

    // 测试array_multisort
//    array_multisort(array_column($data, 'sort'), SORT_DESC, $data);

    $endTime = microtime(true);
    $subTime = $endTime - $startTime;

    echo $subTime;exit;
}

测试结果:
usort :0.29409503936768 波动范围在 0.29 ~ 0.31
array_multisort:0.060003042221069 波动范围在 0.058 ~ 0.078

4、500000数据量

function test()
{
    $data = [];
    for ($i = 1; $i <= 500000; $i++) {
        $data[] = ['sort' => mt_rand(1, 100000000)];
    }

    $startTime = microtime(true);

    // 测试usort
    usort($data, function ($a, $b) {
        if ($a['sort'] == $b['sort']) {
            return 0;
        }
        return $a['sort'] < $b['sort'] ? 1 : -1;
    });

    // 测试array_multisort
//    array_multisort(array_column($data, 'sort'), SORT_DESC, $data);

    $endTime = microtime(true);
    $subTime = $endTime - $startTime;

    echo $subTime;exit;
}

测试结果:
usort :2.0687599182129 波动范围在 2.04 ~ 2.24
array_multisort:0.40970206260681 波动范围在 0.39 ~ 0.41

从测试结果来看,无论数据量多大,array_multisort 的速度都要比 usort 快很多。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值