Heim >Backend-Entwicklung >PHP-Tutorial >php中array multisort排序原理的实例详解

php中array multisort排序原理的实例详解

WBOY
WBOYOriginal
2016-07-25 08:52:161038Durchsuche
  1. $data[] = array('volume' => 67, 'edition' => 2);
  2. $data[] = array('volume' => 86, 'edition' => 1);
  3. $data[] = array('volume' => 85, 'edition' => 6);
  4. $data[] = array('volume' => 98, 'edition' => 2);
  5. $data[] = array('volume' => 86, 'edition' => 6);
  6. $data[] = array('volume' => 67, 'edition' => 7);
  7. ?>
复制代码

例2:

  1. $a = array(1,2,3);
  2. $b = array(3);
  3. // 将数据根据 volume 降序排列,根据 edition 升序排列
  4. // 把 $data 作为最后一个参数,以通用键排序
  5. array_multisort($a, $b, $data);//数组一维个数不同
  6. var_dump( $data);
  7. ?>
复制代码

以上测试代码提示数组不一致的个数。 Warning: array_multisort(): Array sizes are inconsistent in G:\www\test\index.php on line15

再看一个例子:

  1. $data[] = array('volume' => 67, 'edition' => 2);
  2. $data[] = array('volume' => 86, 'edition' => 1);
  3. $data[] = array('volume' => 85, 'edition' => 6);
  4. $data[] = array('volume' => 98, 'edition' => 2);
  5. $data[] = array('volume' => 86, 'edition' => 6);
  6. $data[] = array('volume' => 67, 'edition' => 7, 3, 4,4);//二维个数不同
  7. ?>
复制代码

代码2:

  1. $a = array(11,2,3,4,5,6);
  2. $b = array(3,3,3,3,3,3);
  3. //从结果中看到对应11的array(67,7,3,4,4)按相同顺序出现了;
  4. // 将数据根据 volume 降序排列,根据 edition 升序排列
  5. // 把 $data 作为最后一个参数,以通用键排序
  6. array_multisort($a, $b, $data);
  7. var_dump( $a,$data);
  8. ?>
复制代码

从上面的结果可以得知: 数组参数必须有相同的一维个数; 然后每个数组的对应位置(注意不是相同key,而是从自然位置对应着,如$a(1=>4),对应$b(99=>4) 的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对换。 所以关系就像上面的三个数组,同色的在同一"阵线上",其中一个换,大家要一起换位置。

就介绍这些吧,希望有助于大家理解 multisort 数组排序的用法。

>>> 更多内容,请查看 php数组排序方法大全



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn