Reality Geschrieben 8. März 2007 Geschrieben 8. März 2007 Hallo, kann man irgenwie in c++ den Speicher nach einem Programmdurchlauf einfach wieder löschen? Oder muss man jede einzelne Variable, die man angelegt hat, auch wieder von hand löschen? Mfg, Reality Zitieren
TDM Geschrieben 8. März 2007 Geschrieben 8. März 2007 wenn du mit malloc oder new einen Speicher reservierst, muss du den auch wieder freigeben Zitieren
TDM Geschrieben 8. März 2007 Geschrieben 8. März 2007 mit free oder delete BSP: #define SAFE_DELETE(p) if (p != NULL) {delete p; p = NULL;} class foo { public: foo() { m_pint = new int; } ~foo() {SAFE_DELETE(m_pint)} private: int* m_pint; }; Zitieren
Reality Geschrieben 8. März 2007 Autor Geschrieben 8. März 2007 Ahja, und noch ne blöde frage: wird der dekonstruktor der klasse automatisch aufgerufen, oder muss ich das auch selbst machen? Und wenn der Dekonstruktor dann aufgerufen wird (wie auch immer) werden die Membervariablen der Klasse auch gelöscht? Zitieren
Klotzkopp Geschrieben 8. März 2007 Geschrieben 8. März 2007 Ahja, und noch ne blöde frage: wird der dekonstruktor der klasse automatisch aufgerufen, oder muss ich das auch selbst machen?Destruktor heißt das Ding. Und ob er aufgerufen wird, hängt davon ab, wie du das Objekt angelegt hast. Wenn es eine Autovariable war, passiert das automatisch (daher der Name ), dasselbe gilt für globale Variablen. Bei Objekten, die mit new angelegt wurden, passert das erst, wenn delete aufgerufen wird, dafür bist du verantwortlich. Und wenn der Dekonstruktor dann aufgerufen wird (wie auch immer) werden die Membervariablen der Klasse auch gelöscht?Ja. Zitieren
TDM Geschrieben 8. März 2007 Geschrieben 8. März 2007 Der Destruktor wird aufgerufen, sobald das Objekt terminiert (zerstört) wird. Z.B. bei Auto-Instanzen nach beenden der Funktion. Normale Member werden auch zerstört - Pointer nicht, deswegen das Freigeben des Speichers Ok, Klotzkopp war schneller Zitieren
Klotzkopp Geschrieben 8. März 2007 Geschrieben 8. März 2007 #define SAFE_DELETE(p) if (p != NULL) {delete p; p = NULL;}[/CODE]Die Prüfung auf p != NULL ist hier überflüssig. Zitieren
TDM Geschrieben 8. März 2007 Geschrieben 8. März 2007 Die Prüfung auf p != NULL ist hier überflüssig. Naja, wenn p nicht gesetzt sein würde, probiert er doch NULL zu deleten oder ? Edit: ok, habs nachgelesen, stimmt ist überflüssig: The C++ language guarantees that delete p will do nothing if p is equal to NULL. Since you might get the test backwards, and since most testing methodologies force you to explicitly test every branch point, you should not put in the redundant if test. C++ FAQ (part 08 of 14) Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.