array_udiff_assoc() возвращает array
содержащий все значения параметра array1,
отсутствующие в последующих аргументах.
Обратите внимание, что для сравнения используются ключи, в отличие от функций
array_diff() и array_udiff().
Для сравнения значений массивов используется определённая пользователем функция
обратного вызова. В этом смысле поведение array_udiff_assoc()
отличается от поведения array_diff_assoc(),
которая использует встроенную функцию для сравнения значений.
Пример 1. Пример использования array_udiff_assoc()
<?php class cr { private $priv_member; function cr($val) { $this->priv_member = $val; }
function comp_func_cr($a, $b) { if ($a->priv_member === $b->priv_member) return 0; return ($a->priv_member > $b->priv_member)? 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),);
В примере выше вы видите, что пара "1" => new cr(4)
имеется в обоих массивах и поэтому её нет в выводе функции.
Для сравнения используется функция, определённая пользователем.
Она должна возвращать целое число меньшее, равное или большее нуля, если
первый параметр, соответственно, должен считаться меньше, равен или больше второго.
Замечание:
Пожалуйста, обратите внимание, что эта функция обрабатывает только одно измерение многомерного
массива. Разумеется, вы можете обработать более одного измерения, используя
array_udiff_assoc($array1[0], $array2[0], "some_comparison_func");.