Tiji Geschrieben 25. Januar 2012 Geschrieben 25. Januar 2012 (bearbeitet) Weiss jemand was an diesem Codebeispiel falsch ist ? Syntaktisch ist er auf jeden Fall richtig, jedoch sollten hier mehrere Fehler zu finden sein. Hoffe, dass mir da jemand unter die Arme greifen kann, hab nämlich keine Ahnung ^^ Das Programm muss übrigens keinen wirklich Zweck erfüllen. Das einzige was ich bis jetzt "glaube" zu wissen ist, dass das Überladen für den Zuweisungsoperator für eine Tiefenkopie fehlt, aber das kann nicht alles sein #include <iostream> using namespace std; class B{ }; class A{ int i; B * pB; public: A(): i(2) { pB = new B[10]; } void Ausgabe() { cout <<i<<endl; } ~A() { delete pB; } }; void Func(A &af1, A af2) { af1.Ausgabe(); af2.Ausgabe(); } int main(){ A a, b, *p = new A; a = b; Func(*p,a); return 0; } Bearbeitet 25. Januar 2012 von Tiji
Klotzkopp Geschrieben 26. Januar 2012 Geschrieben 26. Januar 2012 (bearbeitet) Das einzige was ich bis jetzt "glaube" zu wissen ist, dass das Überladen für den Zuweisungsoperator für eine Tiefenkopie fehlt,Da glaubst du richtig. Dazu gehört auch noch ein Copykonstruktor, der beim Kopieren von af2 aufgerufen wird. Durch das fehlende delete von p gibt es ein Speicherleck. Es muss delete[] pB sein. Bearbeitet 26. Januar 2012 von Klotzkopp
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden