AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

EInvalidPointer bei Schliessen eines Frames

Ein Thema von Aves · begonnen am 8. Aug 2009 · letzter Beitrag vom 9. Aug 2009
Antwort Antwort
Aves

Registriert seit: 20. Jul 2009
2 Beiträge
 
Delphi 7 Professional
 
#1

EInvalidPointer bei Schliessen eines Frames

  Alt 8. Aug 2009, 18:48
Hallo zusammen,

ich habe einen abgeleiteten Frame in dem noch einige andere Objekte (Frames und Objekte), teilweise abgeleitet, sind.
Alles (meiner Meinung nach), was ich öffne, schliesse ich auch wieder in der umgekehrten Reihenfolge (duch FreeAndNil).

Jetzt ist es aber so, dass ich im Destroy der Vaterklasse eine AV (EInvalidPointer) habe. Ich habe einen Text in eine Debugdatei geschrieben, daher weiss ich das.

Frame1 und Object1 enthalten ihrerseits auch noch einige andere Objekte. Es ist alles recht unübersichtlich, ich habe teilweise schon aufgeräumt, aber anscheinend noch nicht genug.
Die owner beim Create sind mittlerweile alle auf nil gesetzt.

Delphi-Quellcode:
destructor TAbgeleiteterFrame.Destroy;
begin
  WriteDebugString(TAbgeleitetetKlasse.Destroy');
FreeAndNil(TZusatzFrame1(Frame1));
FreeAndNil(TObject1(Object1));
inherited Destroy;
end;
Delphi-Quellcode:
destructor TVaterFrame.Destroy();
begin
  WriteDebugString(TVaterKlasse.Destroy');
inherited Destroy(); <--- Hier AV
end;
Jetzt ist es ausserdem noch so, dass ich diese AV im Debugger fast nicht habe, eigentlich nur, wenn ich alles noch durch viele Sleeps verlangsame und ständig öffne und schliesse. In der Exe tritt es aber sehr häufig auf, meist nach dem 1. oder 2. Mal schliessen.

Jetzt meine Frage: Wie komme ich dahinter, wodurch das ausgelöst wird? Ich möchte ungern noch mehr Code posten. Wie kann ich meinen Debugger dazu bringen, auch ständig zu diesem EInvalidPointer zu kommen? Oder besser noch, wie kann ich meine Exe dazu bringen, sich genauso wie im Debugger zu verhalten?

Ich hoffe, Ihr könnt mir ein paar Tips geben.
Vielen Dank schon mal im Vorraus!

Aves
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.353 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: EInvalidPointer bei Schliessen eines Frames

  Alt 8. Aug 2009, 19:14
Das hört sich sehr nach Speicherfehlern an. Wenn du nicht gerade eine sehr alte Version von Delphi benutzt, kannst du einfach einmal in den Projektquelltext (Projekt --> Quelltext) folgendes nach dem begin schreiben:ReportMemoryLeaksOnShutdown := True; Da sollte beim Beenden des Projektes keine Meldung kommen, dass Speicher nicht freigegeben wurde.

Wenn du (wie im Profil steht) noch Delphi 7 nutzt, müsstest du dir FastMM selbst herunterladen und einbinden. Dann kannst du das Logging in der Optionsdatei einschalten.

Dann solltest du (insbesondere wenn du dynamische Arrays benutzt) einmal in den Projektoptionen unter Compiler die Bereichsprüfung anschalten, auch da sollten beim Programmablauf keine Fehler kommen, wenn alles ok ist.

Ja, und dann schau einmal selbst ob du beim Erzeugen und Freigeben von Objekten usw. und der Benutzung von Pointern o.ä. irgendetwas auffälliges findest.
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#3

Re: EInvalidPointer bei Schliessen eines Frames

  Alt 8. Aug 2009, 21:18
Ein Problem bei deinem Code ist, dass ein Frame (TAbgeleiteterFrame) sich um einen fremden Frame (TZusatzFrame1(Frame1)) kümmert.
Das ist nicht sauber!
Frames sollten sich gegenseitig oder einseitig nicht kennen.
Es ist Aufgabe des Formulars evtl. nötige Verbindungen / Austausch von Informationen herzustellen.
Übrigens:
wenn eine Komponente (ein Frame ist auch eine Komponente) so erzeugt wird:
FFrameXY := TFrameXY.Create(self); // Owner = self dann ist es doppelt gemoppelt, wenn man im Destruktor das Objekt selbst frei gibt.
Das kann zu Problemen führen - doppelte Freigabe.
fork me on Github
  Mit Zitat antworten Zitat
Aves

Registriert seit: 20. Jul 2009
2 Beiträge
 
Delphi 7 Professional
 
#4

Re: EInvalidPointer bei Schliessen eines Frames

  Alt 9. Aug 2009, 08:26
@jaenicke
Danke für den Tip mit FastMM, das kannte ich nicht. Allerdings sieht es bis jetzt so aus, als ob ich damit nicht weiterkomme. Ich habe direkt nach dem Start und sofortigen Schliessens einige MemoryLeaks (die jetzt nach und nach behoben werden), die werden aber nicht mehr wenn ich den Frame öffne und wieder schliesse. Gibt es sowas wie FastMM auch für das Gegenteil, wenn man also etwas zu oft zerstört?

@sx2008
das wusste ich auch nicht, dass sich Frames nicht kennen sollten. Aber das werde ich auch ändern, ich werde versuchen, das Programm so umzustellen, dass sich die Frames nicht mehr kennen, oder dass ich vielleicht sogar auf den Zusatzframe verzichte... mal sehen

Aves
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:28 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz