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; Пример сортировки массива функцией <function>usort</function> $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 была бы уместнее. Пример сортировки функцией <function>usort</function> многомерного массива $value) { echo "\$fruits[$key]: " . $value["fruit"] . "\n"; } ?> ]]> &example.outputs; При сортировке многомерного массива переменные $a и $b содержат ссылки на первые два индекса массива. Пример сортировки массива функцией <function>usort</function> через функцию-член объекта 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; Пример вызова функции <function>usort</function> <link linkend="functions.anonymous">с замыканием</link> для сортировки многомерного массива '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; Пример работы функции <function>usort</function> с оператором «космический корабль» Оператор «космический корабль» упрощает сравнение составных значений по набору критериев. В следующем примере функция сортирует массив $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;