array_udiff_assoc() retourne un tableau contenant
toutes les valeurs de array1 qui ne sont présentes
dans aucun autre des arguments array2, ....
Notez que les clés sont utilisées dans les comparaisons contrairement Ã
array_diff() et array_udiff().
La comparaison des données est effectuée en utilisant une fonction
callback fournie par l'utilisateur, data_compare_func.
Ce comportement est différent de celui de array_diff_assoc()
qui utilise une fonction de comparaison interne.
Exemple 1. Exemple avec array_udiff_assoc()
<?php class cr { private $priv_member; function cr($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; } } $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),);
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.
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.
Note :
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_assoc($array1[1], $array2[1], "compare_func");.