Platzierung Neu und Löschen
In C ermöglicht die Operatorüberladung die Verwendung benutzerdefinierter Neu- und Löschoperatoren. Dies wirft jedoch die Frage auf, wie der mit solchen Operatoren zugewiesene Speicher korrekt freigegeben werden kann. Betrachten Sie den folgenden Codeausschnitt:
<code class="cpp">const char* charString = "Hello, World"; void *mem = ::operator new(sizeof(Buffer) + strlen(charString) + 1); Buffer* buf = new(mem) Buffer(strlen(charString)); delete (char*)buf; // OR delete buf;</code>
Die Aufgabe der Speicherfreigabe an den überladenen Löschoperator (direkte Methode) zu delegieren, erscheint logisch. Dieser Ansatz ist jedoch falsch.
Richtige Methode
Die richtige Methode zum Freigeben von Speicher besteht in diesem Fall darin, den Destruktor für das Objekt explizit aufzurufen, gefolgt vom Operator Löschfunktion zum Freigeben des zugewiesenen Speichers:
<code class="cpp">buf->~Buffer(); ::operator delete(mem);</code>
Erklärung
Bei Verwendung des Placement-New-Operators, der eine vorab zugewiesene Speicheradresse annimmt, ist der Standardkonstruktor nicht automatisch aufgerufen. Daher ist es wichtig, den Destruktor manuell aufzurufen. Alternativ ist auch der direkte Aufruf von delete buf falsch, da nur der globale Operator delete aufgerufen wird, der nichts über die Platzierung der neuen Zuweisung weiß.
Wann Buf->~Buffer() verwendet werden sollte
Der Destruktoraufruf (buf->~Buffer()) ist immer dann erforderlich, wenn der Placement-New-Operator verwendet wird, auch wenn anschließend die Löschfunktion ::operator aufgerufen wird.
Best Practice
Um Verwirrung zu vermeiden, verwenden Sie immer ein passendes Operatorpaar, wie zum Beispiel:
Das obige ist der detaillierte Inhalt vonWird bei Verwendung von „Placement New' die Zuordnung durch „Löschen' tatsächlich korrekt aufgehoben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!