Table des matières
Vector Push_back et le mystère des invocations multiples de constructeurs de copie
Dynamique vectorielle interne
Optimisation des performances
Maison développement back-end C++ Pourquoi `push_back` déclenche-t-il plusieurs appels de constructeur de copie dans un vecteur ?

Pourquoi `push_back` déclenche-t-il plusieurs appels de constructeur de copie dans un vecteur ?

Nov 01, 2024 am 07:17 AM

Why Does `push_back` Trigger Multiple Copy Constructor Calls in a Vector?

Vector Push_back et le mystère des invocations multiples de constructeurs de copie

Lorsque vous travaillez avec des vecteurs, on peut s'attendre à ce que l'opération push_back ne nécessite qu'une poignée d'appels de constructeur de copie. Cependant, certains cas peuvent révéler un comportement inattendu, comme des appels multiples.

Considérez l'extrait de code suivant :

<code class="cpp">class Myint {
    int my_int;
public:
    Myint() : my_int(0) { /* ... */ }
    Myint(const Myint&amp; x) : my_int(x.my_int) { /* ... */ }
};

int main() {
    vector&lt;Myint&gt; myints;
    Myint x;

    myints.push_back(x); // Call 1
    x.set(1);
    myints.push_back(x); // Call 2
}</code>
Copier après la connexion

Intuitivement, nous nous attendrions à deux appels de constructeur de copie : un pour le premier push_back et un autre pour le second. Cependant, le résultat raconte une autre histoire :

Call 1 (default constructor)
Call 2 (copy constructor: my_int = 0)
Call 3 (copy constructor: my_int = 0)
Call 4 (copy constructor: my_int = 1)
Copier après la connexion

Pourquoi les appels supplémentaires ?

Dynamique vectorielle interne

En interne, un vecteur alloue généralement une certaine quantité de mémoire pour stockage. Lorsque l'espace alloué est épuisé, le vecteur doit réallouer plus de mémoire. Cette réallocation déclenche une copie des éléments existants dans la nouvelle mémoire.

Dans le code donné, le deuxième push_back nécessite une réallocation. Malgré le fait que le constructeur de Myint n'est invoqué que deux fois, le constructeur de copie est utilisé trois fois. En effet, le constructeur de copie est utilisé pour déplacer le premier élément dans la mémoire nouvellement allouée, initialisée avec sa valeur d'origine (my_int = 0), puis le constructeur de copie est à nouveau invoqué pour créer le deuxième élément, initialisé avec la valeur mise à jour ( my_int = 1).

Optimisation des performances

Pour atténuer ces copies inutiles, il est recommandé de :

  • Réserver la mémoire : En augmentant la capacité initiale du vecteur, vous pouvez empêcher la réallocation et minimiser les opérations de copie.
  • Utilisez Emplace_back : Cette méthode vous permet de construire directement un élément sur place, en évitant les copies ou les déplacements.

Dans ce cas, utiliser la réserve pour pré-allouer de la mémoire réduirait efficacement les appels du constructeur de copie à deux. De plus, emplace_back(0) éliminerait complètement la copie, ce qui entraînerait des performances optimales.

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 de ce site Web
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

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quels sont les types de valeurs renvoyées par les fonctions du langage C? Qu'est-ce qui détermine la valeur de retour? Quels sont les types de valeurs renvoyées par les fonctions du langage C? Qu'est-ce qui détermine la valeur de retour? Mar 03, 2025 pm 05:52 PM

Quels sont les types de valeurs renvoyées par les fonctions du langage C? Qu'est-ce qui détermine la valeur de retour?

Gulc: Cibliothèque C construite à partir de zéro Gulc: Cibliothèque C construite à partir de zéro Mar 03, 2025 pm 05:46 PM

Gulc: Cibliothèque C construite à partir de zéro

C Fonction Langue Format de lettre ÉTAPES DE CONVERSION DE CAS C Fonction Langue Format de lettre ÉTAPES DE CONVERSION DE CAS Mar 03, 2025 pm 05:53 PM

C Fonction Langue Format de lettre ÉTAPES DE CONVERSION DE CAS

Quelles sont les définitions et les règles d'appel des fonctions du langage C et quelles sont les Quelles sont les définitions et les règles d'appel des fonctions du langage C et quelles sont les Mar 03, 2025 pm 05:53 PM

Quelles sont les définitions et les règles d'appel des fonctions du langage C et quelles sont les

Utilisation distincte et partage de phrases Utilisation distincte et partage de phrases Mar 03, 2025 pm 05:51 PM

Utilisation distincte et partage de phrases

Où est la valeur de retour de la fonction de langue C stockée en mémoire? Où est la valeur de retour de la fonction de langue C stockée en mémoire? Mar 03, 2025 pm 05:51 PM

Où est la valeur de retour de la fonction de langue C stockée en mémoire?

Comment fonctionne la bibliothèque de modèle standard C (STL)? Comment fonctionne la bibliothèque de modèle standard C (STL)? Mar 12, 2025 pm 04:50 PM

Comment fonctionne la bibliothèque de modèle standard C (STL)?

Comment utiliser efficacement les algorithmes du STL (trier, trouver, transformer, etc.)? Comment utiliser efficacement les algorithmes du STL (trier, trouver, transformer, etc.)? Mar 12, 2025 pm 04:52 PM

Comment utiliser efficacement les algorithmes du STL (trier, trouver, transformer, etc.)?

See all articles