Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi zugriffsverletzung bei Freeandnil (https://www.delphipraxis.net/120531-zugriffsverletzung-bei-freeandnil.html)

MarcoWarm 12. Sep 2008 08:49

Re: zugriffsverletzung bei Freeandnil
 
wie sieht der onClose Event des Formulars aus?

sirius 12. Sep 2008 08:50

Re: zugriffsverletzung bei Freeandnil
 
Dann gehe doch mal mit dem Debugger rein.

Bernhard Geyer 12. Sep 2008 08:52

Re: zugriffsverletzung bei Freeandnil
 
Zitat:

Zitat von MarcoWarm
Jede Ereignisbehandlungsroutine für das Formular oder für dessen untergeordnete Objekte sollte Release anstelle von Free (Delphi) oder Delete (C++) benutzen. Ansonsten kann ein Speicherzugriffsfehler auftreten.

Bei Show gebe ich dir recht. Bei ShowModal tritt dieses Problem nicht auf da ShowModal schon dafür sorgt das sie erst zurückkommt wenn alle Windows-Messages für das Formular abgearbeitet sind.

MarcoWarm 12. Sep 2008 09:01

Re: zugriffsverletzung bei Freeandnil
 
Zitat:

Zitat von Bernhard Geyer
Bei Show gebe ich dir recht. Bei ShowModal tritt dieses Problem nicht auf da ShowModal schon dafür sorgt das sie erst zurückkommt wenn alle Windows-Messages für das Formular abgearbeitet sind.

wieder was gelernt.... danke :-)

Assertor 12. Sep 2008 09:13

Re: zugriffsverletzung bei Freeandnil
 
Hi,

zusätzlich:

Delphi-Quellcode:
try
  form3.showmodal;
finally
  if Assigned(form3) then
  // so bitte nicht, hatten wir ja schon oft im Forum:
  // if Assigned(form3) = true then
    FreeAndNil(Form3);
end;
Hast Du auch mal geprüft, ob das Form nicht schon in der .dpr erzeugt wird? Guck mal unter den Projektoptionen > Formulare nach.

Gruß Assertor

"Der, der bisher nie mit FreeAndNil(FormXYZ) eine Exception bekommen hat" ;)

Edit: Ich denke, es geht bei Release eher um die Freigabe eines Forms durch sich selbst innerhalb der eigenen Ereignisbehandlungsroutinen, damit die Eventhandler zum Ende trotzdem korrekt abgearbeitet werden und der Event-Routine nicht selbst der Boden unter den Füßen weggezogen wird. Ein externes Free/FreeAndNil sollte prinzipiell kein Problem sein.

hanspeter 12. Sep 2008 09:32

Re: zugriffsverletzung bei Freeandnil
 
Den Fehler hatte ich bisher in zwei Zusammenhängen mal gehabt.
1. Wenn in der Form Com/ActiveX verwendet wurden.
Hing damals wohl mit der Freigabe von Interfaces zusammen.

2. Ich habe TMS-Software Komponenten mit eigener Styleverwaltung verwendet.
Hier kam der Fahler irgendwo in der Nachrichtenschleife der Komponenten beim
freigeben. Da wurde wohl zu schnell der Boden unter den Füssen weggezogen.

Um diese Ursache auszuschließen, kann man erst mal versuchen nach Form.Free mit einem
Timer das Form := nil zu verzögern.

Oder als bessere Lösung:

In onClose Action := cafree setzen.
Schließt das Fenster (fast) immer korrekt.
Interessanter Weise ging hier auch ein nil.

Beispiel:
Delphi-Quellcode:
Form := TForm.Create;
...

FreeandNil(Form); --> Fehler

Form.Close;

onClose:
  Action := cafree;
  Form := nil;

funktionierte.
Ich hoffe eine Anregung wie weiter suchen.

Gruß
Peter

renekr 12. Sep 2008 10:49

Re: zugriffsverletzung bei Freeandnil
 
Hi,
verdamm. Mis..

Ich hatte das Problem auch schon öfters.
Bin durchs reindebuggen wieder draufgestoßen.

Habe letzte Woche die TMS Komponenten upgedatet und leider ist in der
destructor TAdvDBLookupComboBox.Destroy noch ein Fehelr drin.
Beim FreeBookmark krachts .
Werde es mal Untersuchen und an TMS Support mailen.

Sry für die Belästigung.
Aber trotzdem Danke für die Infos.Diese waren in bez. Release und Freigeben auch sehr nützlich.

Schönes Weekend.


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:35 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz