array_udiff_uassoc Calcule la différence de deux tableaux associatifs, compare les données et les index avec une fonction de callback &reftitle.description; arrayarray_udiff_uassoc arrayarray1 arrayarray2 array ... callbackdata_compare_func callbackkey_compare_func array_diff_uassoc retourne un array contenant toutes les valeurs de array1 qui ne sont pas présentes dans l'un des autres arguments array2, .... Notez que les clefs sont utilisées dans les comparaisons contrairement à array_diff et array_udiff. Cette comparaison est effectuée par une fonction callback de l'utilisateur : data_compare_func. Ce comportement est différent de celui de array_diff_assoc qui utilise une fonction interne pour les comparaisons. La comparaisons des clefs (indices) est effectuée par la fonction callback key_compare_func. Ce comportement est différent de celui de array_udiff_assoc, vu que cette dernière utilise une fonction interne pour comparer les indices. Exemple avec <function>array_udiff_uassoc</function> 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); ?> ]]> &example.outputs; cr Object ( [priv_member:private] => 9 ) [0.5] => cr Object ( [priv_member:private] => 12 ) [0] => cr Object ( [priv_member:private] => 23 ) ) ]]> Dans notre exemple, vous voyez que la paire "1" => new cr(4) est présente dans les deux tableaux et donc, absente du tableau résultant. Gardez en tête que vous devez fournir deux fonctions callback. Pour la comparaison, la fonction callback de l'utilisateur est utilisée. Cette fonction doit retourner un entier inférieur, égal ou supérieur à zéro si le premier argument est respectivement plus petit, égal ou plus grand que le second. Notez que cette fonction ne vérifie qu'une seule dimension d'un tableau multi-dimensionnel. Vous pouvez, bien sûr, tester une dimension particulière en utilisant par exemple array_udiff_uassoc($array1[0], $array2[0], "data_compare_func", "key_compare_func");. Voir aussi array_diff, array_diff_assoc, array_diff_uassoc, array_udiff, array_udiff_assoc, array_intersect, array_intersect_assoc, array_uintersect, array_uintersect_assoc et array_uintersect_uassoc.