usort
Сортирует массив по значениям через пользовательскую функцию сравнения элементов
&reftitle.description;
trueusort
arrayarray
callablecallback
Функция сортирует массив array на месте по значениям
путем обработки элементов массива пользовательской функцией сравнения для определения порядка.
¬e.sort-unstable;
¬e.no-key-association;
&reftitle.parameters;
array
Входной массив.
callback
&sort.callback.description;
&reftitle.returnvalues;
&return.true.always;
&reftitle.changelog;
&Version;
&Description;
&return.type.true;
&array.changelog.by-ref;
&reftitle.examples;
Пример сортировки массива функцией usort
$value) {
echo "$key: $value\n";
}
?>
]]>
&example.outputs;
Для ещё большего упрощения внутреннего сравнения
указывают оператор «космический корабль» (англ. spaceship).
$b;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
foreach ($a as $key => $value) {
echo "$key: $value\n";
}
?>
]]>
Ясно, что в этом тривиальном случае функция
sort была бы уместнее.
Пример сортировки функцией usort многомерного массива
$value) {
echo "\$fruits[$key]: " . $value["fruit"] . "\n";
}
?>
]]>
&example.outputs;
При сортировке многомерного массива переменные $a
и $b содержат ссылки на первые два индекса массива.
Пример сортировки массива функцией usort через функцию-член объекта
name = $name;
}
/* Статическая функция сравнения: */
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 с замыканием
для сортировки многомерного массива
'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 с оператором «космический корабль»
Оператор «космический корабль» упрощает сравнение
составных значений по набору критериев. В следующем примере
функция сортирует массив $people по фамилии, а затем по имени, если фамилии совпадают.
'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;
uasort
uksort
&seealso.array.sorting;