深入array multisort排序原理的详解

<div class="codetitle"><a style="CURSOR: pointer" data="81393" class="copybut" id="copybut81393" onclick="doCopy('code81393')"> 代码如下:

<div class="codebody" id="code81393">
<?php
$data[] = array('volume' => 67,'edition' => 2);
$data[] = array('volume' => 86,'edition' => 1);
$data[] = array('volume' => 85,'edition' => 6);
$data[] = array('volume' => 98,'edition' => 6);
$data[] = array('volume' => 67,'edition' => 7);
?>

<div class="codetitle"><a style="CURSOR: pointer" data="73107" class="copybut" id="copybut73107" onclick="doCopy('code73107')"> 代码如下:
<div class="codebody" id="code73107">
<?php
$a = array(1,2,3);
$b = array(3);
// 将数据根据 volume 降序排列,根据 edition 升序排列
// 把 $data 作为最后一个参数,以通用键排序
array_multisort($a,$b,$data);//数组一维个数不同
var_dump( $data);
?>

上面这个测试代码提示数组不一致的个数

Warning: array_multisort(): Array sizes are inconsistent in G:\www\test\index.php on line 15

再看

<div class="codetitle"><a style="CURSOR: pointer" data="51080" class="copybut" id="copybut51080" onclick="doCopy('code51080')"> 代码如下:
<div class="codebody" id="code51080">
<?php
$data[] = array('volume' => 67,'edition' => 7,3,4,4);//二维个数不同
?>

<div class="codetitle"><a style="CURSOR: pointer" data="90601" class="copybut" id="copybut90601" onclick="doCopy('code90601')"> 代码如下:
<div class="codebody" id="code90601">
<?php
$a = array(11,5,6);
$b = array(3,3);
//从结果中看到对应11的array(67,7,4)按相同顺序出现了;
// 将数据根据 volume 降序排列,根据 edition 升序排列
// 把 $data 作为最后一个参数,以通用键排序
array_multisort($a,$data);
var_dump( $a,$data);
?>

从上面的结果可以得知:

数组参数必须有相同的一维个数;
<FONT style="COLOR: #ff0000">然后每个数组的对应位置<FONT style="COLOR: #0000ff">(<FONT style="COLOR: #0000ff">注意不是相同key,而是从自然位置对应着,如$a(1=>4),对应$b(99=>4)<FONT style="COLOR: #0000ff"> 的4,因为它们的位置都是第一个,而非key(1,99)的对应关系),对应位置中的值就像穿在一个个互相平等竹杆上一样,穿在上面的其中一个值需要调整位置时,就会导致同一"竹杆"上的其它值出现垂直移动.

类:

$a $b $c
4=>7 8=>10 '999' => 0
9=>9 0=>1 999=>9
0=> 2 9=> 3 9999=>7
----------------------
如果出现按$a的7与9对换,也就会带动$b的10与1对换 $c的0与9对换.
所以关系就像上面的三个数组,同色的在同一"阵线上",其中一个换,大家要一起换位置.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

arraymultisort排序原理

相关推荐


如何选择合适的 C++ Web 开发框架?
利用 C++ 框架构建高并发 Web 应用的策略
用 C++ 框架开发跨平台图形应用程序
golang框架中安全编码实践的最佳指南是什么?
golang框架与其他语言框架在设计理念上的区别有哪些?
C++ 图形框架与其他语言框架的比较
C++ 框架与其他 Web 开发框架的对比分析
使用 C++ 框架构建大型项目最佳实践
C++ 框架如何提高大型项目开发效率
C++ 框架中依赖注入的持续集成与部署工具
如何与社区协作和贡献到自定义 Golang 框架?
C++ 框架在大型项目中如何实现模块化开发
使用 C++ 框架开发跨平台 Web 应用
C++ 框架在大型项目中的优缺点
golang框架在性能上的优势体现在哪些方面?
C++ 框架在嵌入式系统内存优化中的优势
golang框架在人工智能与机器学习中的作用
如何扩展 Golang 框架以支持特定功能?
如何利用 Go Modules 和依赖项管理来自定义 Golang 框架?
Golang 框架中的性能优化技巧