PHP中usort在值相同時改變原始位置問題的解決方案

來源:互聯網
上載者:User

從 PHP 4.1.0 後,usort 在比較的值相同時,原始位置可能會改變,文檔中是這樣說的:
If two members compare as equal, their order in the sorted array is undefined.
也就是說,如果比較的2個值相同,則它們在排序結果中的順序是隨機的。如果你需要保持相同值的原始位置,可以參考本文的方法。
示範資料: 複製代碼 代碼如下:<?php
/*
解決 PHP 中 usort 在值相同時改變原始位置的問題
作者:Artlover http://www.CodeBit.cn
*/
$arr = array(
array('a' => 5, 'b' => 3),
array('a' => 5, 'b' => 1),
array('a' => 5, 'b' => 4),
array('a' => 5, 'b' => 2),
);
?>

數組中第一個元素的值是相同的,期望的結果是保持現有的位置不變,即 b 的順序為 3,1,4,2
用 usort 排序,當比較欄位的值相同時,原始順序可能會改變 複製代碼 代碼如下:<?php
/*
解決 PHP 中 usort 在值相同時改變原始位置的問題
作者:Artlover http://www.CodeBit.cn
*/
$callback = create_function('$a,$b', 'return ($a["a"] == $b["a"])?0:(($a["a"] > $b["a"]) ? 1 : -1);');
usort($arr, $callback);
?>

結果: 複製代碼 代碼如下:Array
(
[0] => Array
(
[a] => 5
[b] => 2
)
[1] => Array
(
[a] => 5
[b] => 4
)
[2] => Array
(
[a] => 5
[b] => 1
)
[3] => Array
(
[a] => 5
[b] => 3
)
)

雖然排序欄位的值相同,但是 usort 卻將整個數組的順序打亂了。
如果要在比較的值相同時保持原始位置,可以用 array_multisort : 複製代碼 代碼如下:<?php
/*
解決 PHP 中 usort 在值相同時改變原始位置的問題
作者:Artlover http://www.CodeBit.cn
*/
// 索引計數器
$i = 0;
// 建立2個空數組,第一個儲存要排序的欄位,第二個儲存原始索引資訊
$a = $index = array();
foreach ($arr as $key => $data) {
$a[$key] = $data['a'];
$index[] = $i++;
}
// 第一個數組先排,接著按原始索引排
array_multisort($a, SORT_ASC, $index, SORT_ASC, $arr);
?>

結果: 複製代碼 代碼如下:Array
(
[0] => Array
(
[a] => 5
[b] => 3
)
[1] => Array
(
[a] => 5
[b] => 1
)
[2] => Array
(
[a] => 5
[b] => 4
)
[3] => Array
(
[a] => 5
[b] => 2
)
)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.