Veröffentlicht 8. März 200718 j 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
8. März 200718 j wenn du mit malloc oder new einen Speicher reservierst, muss du den auch wieder freigeben
8. März 200718 j 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; };
8. März 200718 j 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?
8. März 200718 j 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.
8. März 200718 j 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
8. März 200718 j #define SAFE_DELETE(p) if (p != NULL) {delete p; p = NULL;}[/CODE]Die Prüfung auf p != NULL ist hier überflüssig.
8. März 200718 j 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)
Archiv
Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.