![]() |
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Neue Frage -> Neuer Thread :-D
In der Erklärung des neuen Threads kannst du ja auf diesen hier verlinken damit die Leute wissen worum es geht. |
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Hallo,
habe mir die ganze Sache mal durchgelesen. Ich habe auch große Probleme mit undefinierten Fehlermeldungen. Kann es sein, das Delphi 7 Probleme mit 'self' hat ? Ich Erzeuge auch einige Objekte mit dem Parameter 'self'. Ich bekomme bei einigen Kunden Fehlermeldungen beim Starten meines Progs. Wenn ich in Delphi zu der Adresse des Laufzeitfehlers gehe, springt er in die Unit System zur Procedure:
Delphi-Quellcode:
procedure TObject.Free;
begin if Self <> nil then Destroy; end; |
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Die Frage hast du doch nun schon in einem anderen Thread gestellt :gruebel:
Grundlegend gibt es bei keiner Delphi Version die ich benutze/benutzt habe (D3, D4, D5, D6, D7 und D10) habe ich jemals Probleme mit Self gehabt. Wenn es eine AV in der von dir genannten Stelle gab, dann war immer eine ungültige Referenz der Auslöser. Entweder wurde ein Objekt freigegeben und die Instanzenvariable nicht Nil gesetzt (wie mkinzler im anderen Thread schon sagte). Eine andere Möglichkeit ist, die Instanz wurde in mehreren Variablen abgelegt und eine davon wurde freigegeben, damit wird die anderen unbemerkt ungültigt. Beispiel dazu:
Delphi-Quellcode:
Ein anderer Fall: Die Instanz wurde durch den Owner schon freigegeben: Beispiel: eine Variable TPanel welche ein Panel zugewiesen wurde und als Owner wurde eine Form übergeben. Wenn die Form freigegeben wird, gibt diese auch die TPanel Instanz frei und die Variable enthalt dann eine ungültige Instanz. Auch hier würde im besten Falle eine AV beim Free ausgelöst werden.
Var
lInstanz, lGleicheInstanz: TObject; Begin lInstanz := TObject.Create; lGleicheInstanz := lInstanz; // beide Variablen enthalten die gleiche Instanz und [b]keine Kopie[/b]! lInstanz.Free; // damit wird lGleicheInstanz automatisch mit ungültig! End; Grundlegend sollte Self immer gut sein. Wenn in einer Methode Self NIL ist, dann befindet man sich in einer Methode einer nicht instanziierten Klasse. Dieses kann auch leicht geschehen, wenn man einen virtuellen Constructor versteckt und einen neuen implementiert (Compiler Warnung kann ja mit ReIntroduce unterdrückt werden) und die Klasse aber über die Basisklasse instanziiert wird. |
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Wenn im Constructor eine Exception fliegt wird die Klasse auch sofort wieder zerstört was erklären würde das du in der Methode "free" landest.
|
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Zitat:
|
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Sorry Leute. Ich habe festgestellt, das es an meiner Delphi Installation liegt.
Ich habe Delphi neu installiert. Wenn ich jetzt Delphi starte, habe ich keine Komponenten drin. Und wenn ich es dann beende, bekomme ich genau das Debug Fenster, wie meine Anwender auch... |
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Keine Komponenten? Kann es sein, dass du Delphi unter einem anderen Benutzerkonto installiert hast als dem Konto in dem du es jetzt ausführst?
|
Re: Leidiges EAccessViolation bei dynamischer TabSheet-Erze
Ne. Hab ich nicht. Ich hatte Delphi installiert, und ohne es ein mal zu starten die Jedis installiert. Ich denke das der Fehler daher kommt.
Bin grade am neu installieren... |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:39 Uhr. |
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