usort
Sortiert ein Array nach Werten mittels einer benutzerdefinierten Vergleichsfunktion
&reftitle.description;
trueusortarrayarraycallablecallback
Diese Funktion sortiert array nach seinen Werten
mittels einer benutzerdefinierten Vergleichsfunktion, um die Reihenfolge
zu bestimmen.
¬e.sort-unstable;
¬e.no-key-association;
&reftitle.parameters;
array
Das zu sortierende Array.
callback
&sort.callback.description;
&reftitle.returnvalues;
&return.true.always;
&reftitle.changelog;
&Version;&Description;
&return.type.true;
&array.changelog.by-ref;
&reftitle.examples;
usort-Beispiel
$value) {
echo "$key: $value\n";
}
?>
]]>
&example.outputs;
Der Raumschiff-Operator kann verwendet werden, um den internen Vergleich
noch weiter zu vereinfachen.
$b;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
foreach ($a as $key => $value) {
echo "$key: $value\n";
}
?>
]]>
Für dieses einfache Beispiel wäre die Funktion sort
offensichtlich die bessere Wahl.
usort-Beispiel für mehrdimensionale Arrays
$value) {
echo "\$fruechte[$key]: " . $value["frucht"] . "\n";
}
?>
]]>
&example.outputs;
Wenn ein mehrdimensionales Array sortiert wird, enthalten
$a und $b Verweise auf den
ersten Index des Arrays.
usort-Beispiel, das die Methode eines Objekts benutzt
name = $name;
}
/* Dies ist die statische Vergleichsfunktion */
static function cmp_obj($a, $b)
{
return strtolower($a->name) <=> strtolower($b->name);
}
}
$a[] = new TestObj("c");
$a[] = new TestObj("b");
$a[] = new TestObj("d");
usort($a, [TestObj::class, "cmp_obj"]);
foreach ($a as $item) {
echo $item->name . "\n";
}
?>
]]>
&example.outputs;
usort-Beispiel zum Einsatz einer
Closure zum Sortieren eines
mehrdimensionalen Arrays
'z', 'key_b' => 'c');
$array[1] = array('key_a' => 'x', 'key_b' => 'b');
$array[2] = array('key_a' => 'y', 'key_b' => 'a');
function build_sorter($key) {
return function ($a, $b) use ($key) {
return strnatcmp($a[$key], $b[$key]);
};
}
usort($array, build_sorter('key_b'));
foreach ($array as $item) {
echo $item['key_a'] . ', ' . $item['key_b'] . "\n";
}
?>
]]>
&example.outputs;
usort Beispiel unter Verwendung des Raumschiff-Operators
Der Raumschiff-Operator ermöglicht den einfachen Vergleich von
zusammengesetzten Werten über mehrere Achsen hinweg. Das folgende
Beispiel sortiert $people nach dem Nachnamen und
anschließend, wenn der Nachname übereinstimmt, nach dem Vornamen.
'Adam', 'last' => 'West'];
$people[1] = ['first' => 'Alec', 'last' => 'Baldwin'];
$people[2] = ['first' => 'Adam', 'last' => 'Baldwin'];
function sorter(array $a, array $b) {
return [$a['last'], $a['first']] <=> [$b['last'], $b['first']];
}
usort($people, 'sorter');
foreach ($people as $person) {
print $person['last'] . ', ' . $person['first'] . PHP_EOL;
}
?>
]]>
&example.outputs;
&reftitle.seealso;
uasortuksort&seealso.array.sorting;