AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Anwendung dereferenziert Nullzeiger, keine Exception
Thema durchsuchen
Ansicht
Themen-Optionen

Anwendung dereferenziert Nullzeiger, keine Exception

Ein Thema von Der schöne Günther · begonnen am 8. Okt 2019 · letzter Beitrag vom 9. Okt 2019
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.199 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 09:30
Alles klar. Es ist mir fast peinlich, aber es ist eine globale Variable auf eine TForm (VCL). Dieses Formular ist ein riesiges Spaghetti-Konstrukt mit message -Direktiven wie procedure WMQUERYENDSESSION(var msg: TWMQueryEndSession); message WM_QUERYENDSESSION; . Als das Ding entstand ging ich ehrlich noch in die Grundschule.

Ich bekomme es mit einer neuen TForm nicht nachgestellt.

Und noch eine Sache: Im Debugger ist immer alles gut, keine Exception, der Nullzeiger wird dereferenziert. Führe ich die exakt gleiche Exe direkt aus (also nicht aus der IDE), kommt es normal zur erwarteten Exception.

PS: InstanceSize dieses Formulars liefert 149220 (!)

Geändert von Der schöne Günther ( 9. Okt 2019 um 09:34 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.658 Beiträge
 
Delphi 12 Athens
 
#2

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 09:38
PS: InstanceSize dieses Formulars liefert 149220 (!)
Dann liegt der Offset für den besagten Integer vermutlich außerhalb des gefährdeten Bereichs - zumindest beim Debugging.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.199 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 09:58
Was ist ein gefährdeter Bereich? Und wie wirkt sich das Debugging darauf aus? Ich kenne mich mit den ganzen LowLevel-Sachen nicht aus...

Meinst du dass er sich den Zeigerwert (Null) nimmt, darauf addiert wo der entsprechende Integer sein müsste, und der resultierende Wert ist bereits so groß dass das Betriebssystem meint "Jo, da darf der Knilch lesen"? Aber warum hätte ein laufender Debugger darauf Einfluss? Merkwürdig...

PS: Auch der Einsatz des "FullDebugMode" von FastMM4 bringt keine Änderungen mit sich.

Geändert von Der schöne Günther ( 9. Okt 2019 um 10:29 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.658 Beiträge
 
Delphi 12 Athens
 
#4

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 10:33
Ob dein Programm bzw. die IDE von einem bestimmten, absolutem Speicherbereich lesen darf hängt von der aktuellen Situation ab, und diese kann sich durch den Debugger ändern. Es ist als eher Zufall ob es dabei knallt oder nicht.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.199 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 10:59
Das ist ja wirklich unbefriedigend.

Zumal ich es auch nicht nachgestellt bekomme wenn ich meinen Referenztyp (TForm oder TObject oder was auch immer) soweit aufblase dass die InstanceSize gleich ist.

Im Debugger kommt nie eine Zugriffsverletzung, ohne Debugger kommt immer eine. Ich habe in den Projektoptionen nichts gefunden was das irgendwie noch beinflussen könnte...
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.658 Beiträge
 
Delphi 12 Athens
 
#6

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 11:33
Zumal ich es auch nicht nachgestellt bekomme wenn ich meinen Referenztyp (TForm oder TObject oder was auch immer) soweit aufblase dass die InstanceSize gleich ist.
Steht denn dann auch der Integer an derselben Stelle? Andererseits bedeutet ein anderes Programm auch ein anderes Memory-Layout. Ich würde also immer noch Zufall anführen, wobei Zufall in der Programmierung ja eigentlich nicht existiert. Sagen wir also, die Zusammenhänge sind so komplex, daß es schwierig ist, sie konsistent nachzubilden.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.199 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

AW: Anwendung dereferenziert Nullzeiger, keine Exception

  Alt 9. Okt 2019, 11:39
Mein Nachstellen beschränkte sich auf ein TObject das mit einem statischen Byte-Array von 0 bis 149216 beginnt und danach ein Integer kommt. Also nein, exakt die gleiche Stelle wäre es jetzt nicht gewesen.

Das kann ich auch noch einmal versuchen exakt nachzubilden, aber was weiß ich schon wo der Compiler wirklich die Felder hinlegt? Vielleicht wird da etwas optimiert und hin- und hergeschoben. Vielleicht kann man so etwas im CPU-Fenster bzw. Assemblercode sehen, aber für mich ist das nur Zeichensalat.
  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 18:03 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