Pousser des éléments à partir du même vecteur : une pratique sûre
En programmation, l'utilisation de vecteurs pour stocker des éléments est une technique fondamentale. Cependant, il est essentiel de comprendre les pièges potentiels associés aux opérations sur les vecteurs, en particulier lorsque vous travaillez avec la fonction push_back.
Le problème : pousser des éléments du vecteur
Considérez l'extrait de code suivant :
<code class="cpp">vector<int> v; v.push_back(1); v.push_back(v[0]);</code>
Si la deuxième opération push_back déclenche une réallocation du vecteur, la référence au premier entier (v[0]) devient invalide. Cela pourrait entraîner un comportement inattendu ou même des erreurs de segmentation.
Solution : utiliser la réserve pour empêcher la réaffectation
Pour contourner ce problème et assurer la sécurité de la poussée des éléments à partir du même vecteur, la fonction de réserve peut être utilisée. En réservant à l'avance la capacité nécessaire, le vecteur peut accueillir l'élément supplémentaire sans avoir besoin de réallocation.
<code class="cpp">vector<int> v; v.push_back(1); v.reserve(v.size() + 1); v.push_back(v[0]);</code>
Dans ce code révisé, la réserve est appelée après l'ajout de l'élément initial au vecteur. Cela garantit que le vecteur a une capacité suffisante pour contenir tous les éléments sans risque de réallocation.
Perspective historique
Il est à noter que les inquiétudes entourant cette opération ont été abordé dans la norme C. La proposition 526, qui ciblait les situations où les paramètres pris par référence const pouvaient être modifiés lors de l'exécution de la fonction, a examiné ce problème. Cependant, la proposition a finalement conclu que le comportement n'était pas considéré comme un défaut, car la norme exige que les opérations d'insertion sur les vecteurs fonctionnent correctement, quels que soient les changements internes potentiels.
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!