(PHP 5, PHP 7, PHP 8)
array_udiff_uassoc — Вычисляет расхождение в массивах с дополнительной проверкой индексов, сравнивая значения и индексы через callback-функцию
$array,...$arrays,$value_compare_func,$key_compare_funcФункция вычисляет расхождение в массивах с дополнительной проверкой индексов, сравнивая значения и индексы через callback-функцию.
Обратите внимание, что в отличие от функций array_diff() и array_udiff() при сравнении значений также сравниваются и ключи.
arrayПервый массив.
arraysМассивы для сравнения.
value_compare_func
При возврате из функции сравнения нецелых значений наподобие float
PHP внутренне приведёт значение, которое возвращает callback-функции, к типу int.
Поэтому значения наподобие 0.99 и 0.1
приводятся к целочисленному значению 0
и сравниваются как равные.
Callback-функция сортировки должна обрабатывать любое значение из любого массива в любом порядке независимо от первоначального порядка. Причина состоит в том, что каждый отдельный массив вначале сортируется, а затем сравнивается с другими массивами. Например:
<?php
$arrayA = ["string", 1];
$arrayB = [["value" => 1]];
// В переменных $item1 и $item2 возможны значения "string", 1 или ["value" => 1]
$compareFunc = static function ($item1, $item2) {
$value1 = is_string($item1) ? strlen($item1) : (is_array($item1) ? $item1["value"] : $item1);
$value2 = is_string($item2) ? strlen($item2) : (is_array($item2) ? $item2["value"] : $item2);
return $value1 <=> $value2;
};key_compare_func
Сравнение ключей (индексов) выполняется также callback-функцией
key_compare_func. Это поведение отличается
от поведения функции array_udiff_assoc(),
которая сравнивает индексы через внутреннюю функцию.
Функция возвращает массив (array)
с элементами массива array,
которые не содержатся ни в одном другом массиве.
Пример #1 Пример сравнения массивов функцией array_udiff_uassoc()
<?php
class cr
{
private $priv_member;
function __construct($val)
{
$this->priv_member = $val;
}
static function comp_func_cr($a, $b)
{
if ($a->priv_member === $b->priv_member) return 0;
return ($a->priv_member > $b->priv_member) ? 1 : -1;
}
static function comp_func_key($a, $b)
{
if ($a === $b) return 0;
return ($a > $b) ? 1 : -1;
}
}
$a = array("0.1" => new cr(9), "0.5" => new cr(12), 0 => new cr(23), 1 => new cr(4), 2 => new cr(-15),);
$b = array("0.2" => new cr(9), "0.5" => new cr(22), 0 => new cr(3), 1 => new cr(4), 2 => new cr(-15),);
$result = array_udiff_uassoc($a, $b, array("cr", "comp_func_cr"), array("cr", "comp_func_key"));
print_r($result);
?>Результат выполнения приведённого примера:
Array
(
[0.1] => cr Object
(
[priv_member:cr:private] => 9
)
[0.5] => cr Object
(
[priv_member:cr:private] => 12
)
[0] => cr Object
(
[priv_member:cr:private] => 23
)
)
В приведённом примере видно, что пара "1" => new cr(4)
есть в обоих массивах, и поэтому её нет в выводе функции.
Функция будет работать, только если ей предоставили две функции обратного вызова.
Замечание: Обратите внимание, что функция обрабатывает только первый уровень многомерного массива. Значения на вложенных уровнях обрабатывают, например, так:
array_udiff_uassoc($array1[0], $array2[0], "data_compare_func", "key_compare_func");.