usort

(PHP 3 >= 3.0.3, PHP 4, PHP 5)

usort --  使用會員自訂的比較函數對陣列中的值進行排序

說明

bool usort ( array &array, callback cmp_function )

本函數將用會員自訂的比較函數對一個陣列中的值進行排序。若果要排序的陣列需要用一種不尋常的標準進行排序,那麼應該使用此函數。

比較函數必須在第一個參數被認為小於,等於或大於第二個參數時分別返回一個小於,等於或大於零的整數。

注: 若果兩個成員比較結果相同,則它們在排序後的陣列中的順序未經定義。到 PHP 4.0.6 之前,會員自訂函數將保留這些單元的原有順序。但是由於在 4.1.0 中引進了新的排序算法,結果將不是這樣了,因為對此沒有一個有效的解決專案。

注: 本函數為 array 中的單元賦予新的鍵名。這將移除原有的鍵名而不僅是重新排序。

若果成功則返回 TRUE,失敗則返回 FALSE

例子 1. usort() 例子

<?php
function cmp($a$b)
{
    if (
$a == $b) {
        return 
0;
    }
    return (
$a $b) ? -1;
}

$a = array(32561);

usort($a"cmp");

foreach (
$a as $key => $value) {
    echo 
"$key: $value\n";
}
?>

上例將輸出:

0: 1
1: 2
2: 3
3: 5
4: 6

注: 很明顯在這個小例子中用 sort() 函數更合適。

例子 2. 使用多維陣列的 usort() 例子

<?php
function cmp($a$b)
{
    return 
strcmp($a["fruit"], $b["fruit"]);
}

$fruits[0]["fruit"] = "lemons";
$fruits[1]["fruit"] = "apples";
$fruits[2]["fruit"] = "grapes";

usort($fruits"cmp");

while (list(
$key$value) = each($fruits)) {
    echo 
"\$fruits[$key]: " $value["fruit"] . "\n";
}
?>

當排序多維陣列時,$a$b 包括到陣列第一個索引的引用。

上例將輸出:

$fruits[0]: apples
$fruits[1]: grapes
$fruits[2]: lemons

例子 3. 使用對象的成員函數的 usort() 例子

<?php
class TestObj {
    var 
$name;

    function 
TestObj($name)
    {
        
$this->name $name;
    }

    
/* This is the static comparing function: */
    
function cmp_obj($a$b)
    {
        
$al strtolower($a->name);
        
$bl strtolower($b->name);
        if (
$al == $bl) {
            return 
0;
        }
        return (
$al $bl) ? +: -1;
    }
}

$a[] = new TestObj("c");
$a[] = new TestObj("b");
$a[] = new TestObj("d");

usort($a, array("TestObj""cmp_obj"));

foreach (
$a as $item) {
    echo 
$item->name "\n";
}
?>

上例將輸出:

b
c
d

參見 uasort()uksort()sort()asort()arsort()ksort()natsort()rsort()