ユーザー定義の比較関数を用いて、キーで配列をソートする
&$array
$callback
順序を決めるユーザー定義の比較関数を用いて、 array のキーをソートします。
array
注意: 比較結果が等しくなる二つの要素があった場合、それらの並び順は保持されます。PHP 8.0.0 より前のバージョンでは、ソートした配列におけるそれらの並び順は不定でした。
注意:
比較結果が等しくなる二つの要素があった場合、それらの並び順は保持されます。PHP 8.0.0 より前のバージョンでは、ソートした配列におけるそれらの並び順は不定でした。
注意: この関数をコールすると、配列の内部ポインタは最初の要素にリセットされます。
この関数をコールすると、配列の内部ポインタは最初の要素にリセットされます。
入力の配列。
callback
比較関数は、最初の引数と二番目の引数の比較結果を返します。最初の引数のほうが二番目の引数より大きい場合は正の整数を、二番目の引数と等しい場合はゼロを、そして二番目の引数より小さい場合は負の整数を返す必要があります。
$a
$b
float のような 非整数 を比較関数が返すと、その返り値を内部的に int にキャストして使います。 つまり、0.99 や 0.1 といった値は整数値 0 にキャストされ、 値が等しいとみなされます。
0.99
0.1
0
常に true を返します。
true
E_WARNING
例1 uksort の例
<?php function cmp($a, $b) { $a = preg_replace('@^(a|an|the) @', '', $a); $b = preg_replace('@^(a|an|the) @', '', $b); return strcasecmp($a, $b); } $a = array("John" => 1, "the Earth" => 2, "an apple" => 3, "a banana" => 4); uksort($a, "cmp"); foreach ($a as $key => $value) { echo "$key: $value\n"; } ?>
上の例の出力は以下となります。
an apple: 3 a banana: 4 the Earth: 2 John: 1