array_udiff() возвращает массив,
содержащий все значения параметра array1,
отсутствующие в последующих аргументах.
Обратите внимание, что ключи сохраняются. Для сравнения значений
используется функция data_compare_func.
Она должна возвращать целое число меньшее, равное или большее нуля, если
первый параметр, соответственно, должен считаться меньше, равен или больше второго.
Обратите внимание на отличие от array_diff(), которая использует
встроенную функцию для сравнения значений массивов.
Пример 1. Пример использования array_udiff()
<?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),);
Замечание:
Обратите внимание, что эта функция обрабатывает только одно измерение многомерного
массива. Разумеется, вы можете обработать более одного измерения, используя
array_udiff($array1[0], $array2[0], "data_compare_func");.