AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren

SystemException Ursache finden

Ein Thema von akuk · begonnen am 14. Apr 2020 · letzter Beitrag vom 17. Apr 2020
Antwort Antwort
Seite 1 von 2  1 2   
akuk

Registriert seit: 8. Mär 2020
Ort: Wald, Zürich Oberland
51 Beiträge
 
Delphi 10.3 Rio
 
#1

AW: SystemException Ursache finden

  Alt 14. Apr 2020, 15:50
Hallo
Vielen Dank für Euere Hilfe.
Kann dies eine Exception auslösen ?

(aus vcl.Forms) :

function TCustomForm.IsFormSizeStored: Boolean;
begin
Result := AutoScroll or (HorzScrollBar.Range <> 0) or (VertScrollBar.Range <> 0);
end;
Anton Kurka
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.600 Beiträge
 
Delphi 7 Professional
 
#2

AW: SystemException Ursache finden

  Alt 14. Apr 2020, 16:11
Ja, wenn das Formular vorher nicht erstellt oder vorher freigeben wurde.

Hast Du dort ein konkretes Problem?

Im Debugger die Werte alle anschauen.

Der Debugger müsste Dir sagen können, ob da irgendwas nicht initialisiert ist ...

Aber zugegeben: An soeiner Stelle würde ich keinen Fehler vermuten.

Wie bist Du dahinter gekommen, dass dort ein Fehler sein könnte?
Könntest Du eventuell den Quelltext, der zum Aufruf von IsFormSizeStored oder den Aufruf von IsFormSizeStored enthält posten?

Eventuell lässt sich die Fehlerursache dadurch weiter einkreisen.
  Mit Zitat antworten Zitat
Scurra

Registriert seit: 19. Jan 2015
81 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 06:43
In unserer Software bekommen wir gelegentlich auch Fehlerberichte von Fehlern in dieser Funktion. Bei uns liegt es an einer fehlerhaften Komponente, die im Destruktor gelegentlich Exceptions auslöst. Der Destruktor wird wiederum vom Destruktor des Formulars aufgerufen.
Nach meinem Verständnis wird dadurch das Formular, auf dem die Komponente liegt, nicht freigegeben (oder evtl. nur die Referenz auf unsere Formularvariable nicht zurückgesetzt), was beim Schließen der Anwendung dazu führt, dass die Anwendung erneut versucht, das Formular freizugeben. Das führt dann zu dem Fehler in der Methode IsFormSizeStored. Das liegt aber nicht an der Funktion, sondern ist nur ein Folgefehler eines vorher auftretenden Fehlers.

Geändert von Scurra (15. Apr 2020 um 06:48 Uhr)
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.277 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 07:02
Hallo,
schrittweise Code ausklammern, bis der Fehler nicht mehr kommt.
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.598 Beiträge
 
Delphi 12 Athens
 
#5

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 08:52
Hat die Komponente Property/Verlinkungen zu anderen Komponenten auf der Form?

Bei selbstgebauten Komponenten wird gern vergessen Diese ordentlich zu behandeln.
z.B. TDataSet und TDataSource, wenn du das DataSet löschst, dann wird die DataSource informiert und setzt ihr DataSet-Property auf nil.




Die Komponente wird eigentlich immer freigegeben, aber bei Dingen in der Komponente...

Wenn es beim Freigeben knallt, dann bricht das ja zwischendrin ab,
aber im Constructor und Destructor befinden sich ein Try-Except, was zumindestens den Speicher des Objekts selbst abräumt.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (15. Apr 2020 um 08:54 Uhr)
  Mit Zitat antworten Zitat
akuk

Registriert seit: 8. Mär 2020
Ort: Wald, Zürich Oberland
51 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 09:40
@Delphi.Narium

"Wie bist Du dahinter gekommen, dass dort ein Fehler sein könnte?"

In dem ich die Adresse die bei der Exception angegeben wurde im
->suchen ->zu Adresse springen, eingegeben habe, ist es falsch ?

Aufruf von IsFormSizeStored habe ich niergens gefunden, es ist ja eine vcl Methode ?
darum wird es vermutlich niergens zu finden sein, oder ?
Anton Kurka
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.277 Beiträge
 
Delphi 10.4 Sydney
 
#7

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 09:46
Hallo,
dann benutze halt MadExcept, um den Auslöser zu finden.
Je nach Größe des Projektes sage ich aber trotzdem "Code so lange ausklammern, bis die Exception nicht mehr kommt".

Arbeitest Du mit Interfaces?
Die erzeugen bei falscher Benutzung auch die "lustigsten" Meldungen an Stellen, wo du gar nicht dran warst.
Das meistens durch Speicherüberschreiben.
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.598 Beiträge
 
Delphi 12 Athens
 
#8

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 09:47
Das ist die Stelle, welche geknallt hat.
Der "eigentlich" Fehler wird in diese Zeile selber nicht sein.

Dafür würde sich ein Blick in den Stacktrace anbieten, um zu sehen was zum Aufruf dieser Codestelle führte, und wo der Fehler eher zu vermuten ist. (wo z.B ein NIL oder ein ungültiger Objektzeiger verwendet wurde)



Schlimmer wird es, wenn du irgendwo z.B. einen Buffer-Overflow hast, bei dem fremder Speicher zerstört wird und was dann erst später irgendwo anders "eventuell" knallt, sobald da drauf zugegriffen wird.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (15. Apr 2020 um 09:49 Uhr)
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.600 Beiträge
 
Delphi 7 Professional
 
#9

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 10:11
@Delphi.Narium

"Wie bist Du dahinter gekommen, dass dort ein Fehler sein könnte?"

In dem ich die Adresse die bei der Exception angegeben wurde im
->suchen ->zu Adresse springen, eingegeben habe, ist es falsch ?

Aufruf von IsFormSizeStored habe ich niergens gefunden, es ist ja eine vcl Methode ?
darum wird es vermutlich niergens zu finden sein, oder ?
Nein, das ist nicht falsch, es ist genau der Weg, wie ich auch nach Fehlern suche.

Das Problem ist nun halt leider, dass die Fehlerursache irgendwo "davor" im Programm liegt.

Mein Vorgehen ist in so einem Fall:

Debugger benutzen.
Einen Haltepunkt auf genau diese Zeile setzen.
Programm starten.

Wenn der Debugger nun an dem Haltepunkt stehen bleibt (oder durch Auslösen des Fehlers) im Debugger in Einzelschritten weitergehen und schauen, wo genau Du im eigenen Quelltext "landest". Das kann zuweilen dauern und sehr nervtötend sein.

Wenn Du nun (mehr oder weniger schnell) im eigenen Quelltext landest, dort den Quelltext vor dieser Stelle überprüfen.
Wird da was freigegeben, was nicht freigegben werden sollte?
Fehlerprüfung für alle Eventualitäten einbauen ...

Notfalls, wie weiter oben schon angeregt, "großflächig" auskommentieren, bis der Fehler nicht mehr auftritt. Dann stückweise die Auskommentierung wieder entfernen, um so der Fehlerstelle näherzukommen.

Eventuell mal hier schauen https://www.delphipraxis.net/187827-...einer-ist.html ab Post #19.

Geändert von Delphi.Narium (15. Apr 2020 um 10:12 Uhr) Grund: Schreibfehler, wie immer :-(
  Mit Zitat antworten Zitat
akuk

Registriert seit: 8. Mär 2020
Ort: Wald, Zürich Oberland
51 Beiträge
 
Delphi 10.3 Rio
 
#10

AW: SystemException Ursache finden

  Alt 15. Apr 2020, 11:15
@Himitsu
%S,Danke, es ist nicht ein Fehler beim Kopieren, sondern schlicht vergessen gange.
Anton Kurka
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2   

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 11:05 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