Tiji Geschrieben 25. Januar 2012 Teilen 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 Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 26. Januar 2012 Teilen 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 Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Tiji Geschrieben 26. Januar 2012 Autor Teilen Geschrieben 26. Januar 2012 Danke vielmals Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
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.