Lorsque vous travaillez avec de la mémoire dynamique en C, la gestion des objets et la libération de mémoire peuvent être déroutantes. Cet article aborde l'idée fausse de la suppression d'objets en C.
Considérez l'extrait de code suivant :
<code class="cpp">tempObject obj1; tempObject obj2; vector<tempObject> tempVector; tempVector.push_back(obj1); tempVector.push_back(obj2);</code>
L'appel de clear() sur le vecteur détruira les objets qui y sont stockés. Cependant, cela ne libère pas automatiquement la mémoire allouée. Pour libérer la mémoire, une action plus explicite est nécessaire.
<code class="cpp">vector<tempObject>().swap(tempVector);</code>
L'échange d'un vecteur vide avec l'original libère effectivement la mémoire occupée par tempVector.
Si tempVector était plutôt défini comme un vecteur de pointeurs vers des objets :
<code class="cpp">vector<tempObject *> *tempVector; // Push objects... tempVector->clear();</code>
Dans ce cas, clear() désalloue la mémoire pour les objets pointés par les pointeurs dans le vecteur, mais les pointeurs eux-mêmes restent doivent être supprimés.
Bien que clear() détruit les objets dans un vecteur, il ne libère pas la mémoire allouée. Pour récupérer complètement la mémoire, des actions explicites comme l'échange avec un vecteur vide ou l'utilisation de Shrink_to_fit() en C 11 sont nécessaires. Il est important de comprendre ces nuances pour gérer efficacement la mémoire dans les programmes C.
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!