|
If two members compare as equal, their order in the sorted array is undefined.
也就是說,如果比較的2個(gè)值相同,則它們?cè)谂判蚪Y(jié)果中的順序是隨機(jī)的。如果你需要保持相同值的原始位置,可以參考本文的方法。
演示數(shù)據(jù):
復(fù)制代碼 代碼如下:
<?php
/*
解決 php 中 usort 在值相同時(shí)改變?cè)嘉恢玫膯栴}
作者: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),
);
?>
數(shù)組中第一個(gè)元素的值是相同的,期望的結(jié)果是保持現(xiàn)有的位置不變,即 b 的順序?yàn)?3,1,4,2
用 usort 排序,當(dāng)比較字段的值相同時(shí),原始順序可能會(huì)改變
復(fù)制代碼 代碼如下:
<?php
/*
解決 php 中 usort 在值相同時(shí)改變?cè)嘉恢玫膯栴}
作者: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);
?>
結(jié)果:
復(fù)制代碼 代碼如下:
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 卻將整個(gè)數(shù)組的順序打亂了。
如果要在比較的值相同時(shí)保持原始位置,可以用 array_multisort :
復(fù)制代碼 代碼如下:
<?php
/*
解決 php 中 usort 在值相同時(shí)改變?cè)嘉恢玫膯栴}
作者:Artlover http://www.CodeBit.cn
*/
// 索引計(jì)數(shù)器
$i = 0;
// 創(chuàng)建2個(gè)空數(shù)組,第一個(gè)保存要排序的字段,第二個(gè)保存原始索引信息
$a = $index = array();
foreach ($arr as $key => $data) {
$a[$key] = $data['a'];
$index[] = $i++;
}
// 第一個(gè)數(shù)組先排,接著按原始索引排
array_multisort($a, SORT_ASC, $index, SORT_ASC, $arr);
?>
結(jié)果:
復(fù)制代碼 代碼如下:
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
)
)
php技術(shù):PHP中usort在值相同時(shí)改變?cè)嘉恢脝栴}的解決方法,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。