亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入array multisort排序原理的詳解

 更新時間:2013年06月18日 16:35:01   作者:  
本篇文章是對array multisort排序原理進行了詳細的分析介紹,需要的朋友參考下
復制代碼 代碼如下:

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

復制代碼 代碼如下:

<?php
$a = array(1,2,3);
$b = array(3);
// 將數(shù)據(jù)根據(jù) volume 降序排列,根據(jù) edition 升序排列
// 把 $data 作為最后一個參數(shù),以通用鍵排序
array_multisort($a, $b, $data);//數(shù)組一維個數(shù)不同
var_dump( $data);
?>

上面這個測試代碼提示數(shù)組不一致的個數(shù)
<b>Warning</b>: array_multisort(): Array sizes are inconsistent in <b>G:\www\test\index.php</b> on line <b>15</b><br/>
再看
復制代碼 代碼如下:

<?php
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7, 3, 4,4);//二維個數(shù)不同
?>

復制代碼 代碼如下:

<?php
$a = array(11,2,3,4,5,6);
$b = array(3,3,3,3,3,3);
//從結(jié)果中看到對應11的array(67,7,3,4,4)按相同順序出現(xiàn)了;
// 將數(shù)據(jù)根據(jù) volume 降序排列,根據(jù) edition 升序排列
// 把 $data 作為最后一個參數(shù),以通用鍵排序
array_multisort($a, $b, $data);
var_dump( $a,$data);
?>

從上面的結(jié)果可以得知:
數(shù)組參數(shù)必須有相同的一維個數(shù);
然后每個數(shù)組的對應位置(注意不是相同key,而是從自然位置對應著,如$a(1=>4),對應$b(99=>4) 的4,因為它們的位置都是第一個,而非key(1,99)的對應關系),對應位置中的值就像穿在一個個互相平等竹桿上一樣,穿在上面的其中一個值需要調(diào)整位置時,就會導致同一"竹桿"上的其它值出現(xiàn)垂直移動.
 
類:
$a           $b          $c
4=>7    8=>10       '999' => 0
9=>9   0=>1       999=>9
0=> 2   9=> 3    9999=>7
----------------------
如果出現(xiàn)按$a的7與9對換,也就會帶動$b的10與1對換 $c的0與9對換.
所以關系就像上面的三個數(shù)組,同色的在同一"陣線上",其中一個換,大家要一起換位置.

相關文章

最新評論