uasort

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

uasortユーザー定義の比較関数で配列をソートし、連想インデックスを保持する

説明

uasort(array &$array, callable $callback): bool

インデックスとそれに対応する要素を関連づけて array をソートします。 ソートには、ユーザー定義の比較関数を使います。

主に実際の配列の順序に意味がある連想配列をソートするためにこの関数は使用されます。

注意:

比較結果が等しくなる二つの要素があった場合、それらの並び順は保持されます。PHP 8.0.0 より前のバージョンでは、ソートした配列におけるそれらの並び順は不定でした。

注意:

この関数をコールすると、配列の内部ポインタは最初の要素にリセットされます。

パラメータ

array

入力の配列。

callback

比較関数は、最初の引数と二番目の引数の比較結果を返します。最初の引数のほうが二番目の引数より大きい場合は正の数を、二番目の引数と等しい場合はゼロを、そして二番目の引数より小さい場合は負の数を返す必要があります。

callback(mixed $a, mixed $b): int

戻り値

常に true を返します。

変更履歴

バージョン 説明
8.0.0 callback がリファレンス渡しされる引数を期待している場合、 この関数は E_WARNING を発生させるようになりました。

例1 基本的な uasort() の例

<?php
// 比較用の関数
function cmp($a$b) {
    if (
$a == $b) {
        return 
0;
    }
    return (
$a $b) ? -1;
}

// ソートしたい配列
$array = array('a' => 4'b' => 8'c' => -1'd' => -9'e' => 2'f' => 5'g' => 3'h' => -4);
print_r($array);

// ソートした結果の配列を表示します
uasort($array'cmp');
print_r($array);
?>

上の例の出力は以下となります。

Array
(
    [a] => 4
    [b] => 8
    [c] => -1
    [d] => -9
    [e] => 2
    [f] => 5
    [g] => 3
    [h] => -4
)
Array
(
    [d] => -9
    [h] => -4
    [c] => -1
    [e] => 2
    [g] => 3
    [a] => 4
    [f] => 5
    [b] => 8
)

参考

関連キーワード:  関数, 配列, 比較, ソート, ユーザー, 定義, 保持, インデックス, 連想, uasort