usort

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

usort --  ユーザー定義の比較関数により値で配列をソートします

Description

void usort ( array array, callback cmp_function)

この関数は、ユーザー定義の比較関数により配列をその値でソートします。 ソートしたい配列を複雑な基準でソートする必要がある場合、 この関数を使用するべきです。

比較関数は、最初の引数が2番目の引数より小さいか、等しいか、大きい 場合に、それぞれゼロ未満、ゼロに等しい、ゼロより大きい整数を返す 必要があります。

注意: 二つのメンバーの比較結果が等しいとなった場合、 ソートされた配列の順番は定義されません。PHP4.0.6まではユーザー定義関数は それらの要素の順番を維持します。しかしPHP4.1.0以降で導入された新しい ソートアルゴリズムではそれと同等のことを行う効果的な方法はありません。

例 1. usort() の例

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

$a = array (3, 2, 5, 6, 1);

usort ($a, "cmp");

while (list (
$key, $value) = each ($a)) {
    echo
"$key: $value\n";
}
?>

この例は以下を表示します:

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

注意: もちろん、このような簡単な例ではrsort()関数 の方がより適当です。

例 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 は配列の最初のインデックス への参照を保持していまY。

この例の出力は以下となります:

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

例 3. usort()でオブジェクトのメンバ関数を使用する例

<?php
class TestObj {
    var
$name;

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

    
/* 静的な比較関数: */
    
function cmp_obj($a, $b)
    {
        
$al = strtolower($a->name);
        
$bl = strtolower($b->name);
        if (
$al == $bl) return 0;
        return (
$al > $bl) ? +1 : -1;
    }
}

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

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

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

この例の出力は以下のようになります:

b
c
d

uasort(), uksort(), sort(), asort(), arsort(),ksort(), natsort(), rsort() も参照してください。