sort

(PHP 4, PHP 5, PHP 7, PHP 8)

sort對(duì)數(shù)組升序排序

說(shuō)明

sort(array &$array, int $flags = SORT_REGULAR): bool

對(duì) array 本身按照值(value)升序排序。

注意:

如果兩個(gè)成員完全相同,那么它們將保持原來(lái)的順序。 在 PHP 8.0.0 之前,它們?cè)谂判驍?shù)組中的相對(duì)順序是未定義的。

注意: 此函數(shù)為 array 中的元素賦與新的鍵名。這將刪除原有的鍵名,而不是僅僅將鍵名重新排序。

注意:

重置數(shù)組中的內(nèi)部指針,指向第一個(gè)元素。

參數(shù)

array

輸入的數(shù)組。

flags

可選的第二個(gè)參數(shù) flags 可以用以下值改變排序的行為:

排序類(lèi)型標(biāo)記:

  • SORT_REGULAR - 正常比較單元 詳細(xì)描述參見(jiàn) 比較運(yùn)算符 章節(jié)
  • SORT_NUMERIC - 單元被作為數(shù)字來(lái)比較
  • SORT_STRING - 單元被作為字符串來(lái)比較
  • SORT_LOCALE_STRING - 根據(jù)當(dāng)前的區(qū)域(locale)設(shè)置來(lái)把單元當(dāng)作字符串比較,可以用 setlocale() 來(lái)改變。
  • SORT_NATURAL - 和 natsort() 類(lèi)似對(duì)每個(gè)單元以“自然的順序”對(duì)字符串進(jìn)行排序。
  • SORT_FLAG_CASE - 能夠與 SORT_STRINGSORT_NATURAL 合并(OR 位運(yùn)算),不區(qū)分大小寫(xiě)排序字符串。

返回值

總是返回 true 。

范例

示例 #1 sort() 例子

<?php

$fruits 
= array("lemon""orange""banana""apple");
sort($fruits);
foreach (
$fruits as $key => $val) {
    echo 
"fruits[" $key "] = " $val "\n";
}

?>

以上例程會(huì)輸出:

fruits[0] = apple
fruits[1] = banana
fruits[2] = lemon
fruits[3] = orange

fruits 被按照字母順序排序。

示例 #2 使用 sort() 不區(qū)分大小寫(xiě)自然排序的例子

<?php

$fruits 
= array(
    
"Orange1""orange2""Orange3""orange20"
);
sort($fruitsSORT_NATURAL SORT_FLAG_CASE);
foreach (
$fruits as $key => $val) {
    echo 
"fruits[" $key "] = " $val "\n";
}

?>

以上例程會(huì)輸出:

fruits[0] = Orange1
fruits[1] = orange2
fruits[2] = Orange3
fruits[3] = orange20

fruits 排序得像 natcasesort() 的結(jié)果。

注釋

注意: 和大多數(shù) PHP 排序函數(shù)一樣,sort() 使用了 ? 快速排序 實(shí)現(xiàn)的。 在已排序的數(shù)組分片的中間,選擇基準(zhǔn)值,具有最優(yōu)時(shí)間。 但不應(yīng)該依賴(lài)它實(shí)現(xiàn)的細(xì)節(jié)。

警告

在對(duì)含有混合類(lèi)型值的數(shù)組 以 flagsSORT_REGULAR 排序時(shí)要小心,因?yàn)? sort() 可能會(huì)產(chǎn)生不可預(yù)知的結(jié)果。

參見(jiàn)