Maison  >  Article  >  développement back-end  >  Pourquoi l'opérateur ( ) échoue-t-il lors de la combinaison de tableaux PHP ?

Pourquoi l'opérateur ( ) échoue-t-il lors de la combinaison de tableaux PHP ?

DDD
DDDoriginal
2024-10-24 10:38:29991parcourir

Why Does the ( ) Operator Fail When Combining PHP Arrays?

Concaténation de tableaux en PHP : pourquoi l'opérateur échoue

Lorsque vous essayez de joindre des tableaux à l'aide de l'opérateur " ", vous pouvez rencontrer des résultats inattendus. Considérez le code suivant :

$array = array('Item 1');
$array += array('Item 2');
var_dump($array);

Sortie :

array(1) {
  [0] => string(6) "Item 1"
}

Pourquoi cela ne fonctionne-t-il pas ?

Clés et doublons

Le problème réside dans les clés du tableau et les valeurs en double. Les deux tableaux du code donné ont des clés de « 0 », ce qui entraîne l'écrasement des valeurs en double. Pour conserver l'ordre d'origine et éviter la duplication, PHP utilise la première valeur de la clé "0".

Solution : Fusion de tableaux

Pour concaténer correctement les tableaux, utilisez array_merge ():

$arr1 = array('foo'); // Same as array(0 => 'foo')
$arr2 = array('bar'); // Same as array(0 => 'bar')
$combined = array_merge($arr1, $arr2);

array_merge() fusionne les tableaux, en préservant les paires clé-valeur.

Quand utiliser l'opérateur

L'opérateur " " est toujours utile lors de la combinaison de tableaux avec différentes clés :

$arr1 = array('one' => 'foo');
$arr2 = array('two' => 'bar');
$combined = $arr1 + $arr2;

Cela entraînera :

array('one' => 'foo', 'two' => 'bar');

En résumé, utilisez array_merge() pour concaténer des tableaux afin de préserver l'ordre et d'éviter les conflits de clés . Utilisez l'opérateur " " pour fusionner des tableaux avec des clés uniques.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn