AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Delphi Ausführung eines Klassendestruktors OS-abhängig?
Thema durchsuchen
Ansicht
Themen-Optionen

Ausführung eines Klassendestruktors OS-abhängig?

Offene Frage von "stahli"
Ein Thema von Der schöne Günther · begonnen am 24. Mär 2014 · letzter Beitrag vom 3. Apr 2014
Antwort Antwort
Seite 1 von 2  1 2      
Der schöne Günther

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

Ausführung eines Klassendestruktors OS-abhängig?

  Alt 24. Mär 2014, 13:47
Chaos und Verwirrung. Meine Welt ist normalerweise so klein, dass sich sowohl Entwicklung als auch Auslieferung auf Windows 7 vollzieht.

Ausnahmsweise musste nun etwas noch auf Windows XP laufen. Und ich muss schockiert feststellen: Der Klassendestruktor wird nicht ausgeführt.

Gegeben sei
Delphi-Quellcode:
  TMySingleton = class
     class destructor Destroy();
     class constructor Create();
  end;
und
Delphi-Quellcode:
class constructor TMySingleton.Create();
begin
   ShowMessage('Das ist der Klassenkonstruktor');
end;

class destructor TMySingleton.Destroy();
begin
   ShowMessage('Das ist der Klassendestruktor');
end;

initialization
   Winapi.Windows.MessageBox(0, 'initialization', '', 0);

finalization
   Winapi.Windows.MessageBox(0, 'finalization', '', 0);
Auf Windows 7 wird alles wie erwartet ausgeführt:
  1. Das ist der Klassenkonstruktor
  2. initialization
  3. (...)
  4. finalization
  5. Das ist der Klassendestruktor

Auf Windows XP:
  1. Das ist der Klassenkonstruktor
  2. initialization
  3. (...)
  4. finalization


Warum ist das so? Das kann doch nicht gewollt sein? Wie verhält sich das auf iOS, Android und Mac?

Geändert von Der schöne Günther (24. Mär 2014 um 13:47 Uhr) Grund: Der Titel hat nun ein Fragezeichen am Schluss. Ich hoffe euch damit zusätzliches Lesevergnügen bereitet zu haben.
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.016 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#2

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 24. Mär 2014, 15:14
Sicher, dass in deinem Programm auf XP auch die Klasse irgendwo referenziert wird? Ist das nicht der Fall, dann werden auch Klassen Konstruktor/Destruktor nicht ausgeführt (das ist der schöne Unterschied zum initialization/finalization Block)

Edit: Vergisses - der Konstruktor wurde ja ausgeführt... hmmm

Hast du mal eine andere Form des "Logging" benutzt? Hast du mal mit einem Stoppunkt im Destruktor debuggt?

P.S. Eeeek, Singleton!
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (24. Mär 2014 um 15:25 Uhr)
  Mit Zitat antworten Zitat
Daniel
(Co-Admin)

Registriert seit: 30. Mai 2002
Ort: Hamburg
13.920 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 24. Mär 2014, 16:00
Kann es sein, dass sich Deine App mit ihren MessageBoxen verheddert? MessageBoxen im Finalization-Abschnitt waren meines Wissens noch nie eine gute Idee.
Ich habe eben mit Delphi XE5 eine Konsolen-Anwendung geschrieben und die jeweiligen Code-Stellen eine Ausgabe mit WriteLn() erzeugen lassen.
Klappt unter Windows 8.1 ebenso wie unter Windows XP völlig korrekt auf die erwartete Weise.
Daniel R. Wolf
mit Grüßen aus Hamburg
  Mit Zitat antworten Zitat
Der schöne Günther

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

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 24. Mär 2014, 17:31
Ja, in einer Konsolen-Anwendung mit WriteLn(..) klappt es auf allen Systemen wie erwartet. Komisch.

In meinem konkreten Fall waren es natürlich keine Messageboxen, sondern das abschließende Schreiben der Einstellungen beim Beenden der Anwendung. Auf dem XP-Rechner wurde die Datei noch nicht einmal angelegt (TIniFile.UpdateFile() )

Ich hätte auch grade auf einer XP VM schwören können, die Klassendestruktor-Messagebox einmal kurz aufblitzen zu sehen. Ich habe keinen XP-Rechner mit RAD Studio zur Hand und mit Remote Debugging habe ich auch keine Erfahrung. Deshalb kann ich hier nur so amateurhafte Beobachtungen machen

Wo könnte ich denn anfangen zu suchen, woran es liegt?


PS: Füge ich in meiner VCL-Anwendung ein OutputDebugString(Text: PChar) hinzu, kann man das mit Tools wie DebugView noch sehen.

Mein Titel ist also falsch: Der Klassen-Destruktor wird sehr wohl ausgeführt, aber anscheinend funktioniert die Hälfte darin (Messageboxen, Dateioperationen) nicht mehr vernünftig. Oder er zieht sich selbst nach ein paar Millisekunden den Boden unter den Füßen weg. Ich weiß es nicht.

Gibt es allgemeine Richtlinien, was man dort noch tun darf?
Miniaturansicht angehängter Grafiken
unbenannt.png  

Geändert von Der schöne Günther (24. Mär 2014 um 17:46 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.016 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#5

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 24. Mär 2014, 18:15
Eventuell liegt das daran (dass der nach allen finalizations läuft), dass du manche Sachen nicht mehr korrekt ausführen kannst.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von JamesTKirk
JamesTKirk

Registriert seit: 9. Sep 2004
Ort: München
604 Beiträge
 
FreePascal / Lazarus
 
#6

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 25. Mär 2014, 07:16
Eventuell liegt das daran (dass der nach allen finalizations läuft), dass du manche Sachen nicht mehr korrekt ausführen kannst.
Class Destruktoren laufen nicht nach allen finalization Sections. Alle Units werden in umgekehrter Reihenfolge zur Initialisierung finalisiert und innerhalb jeder Unit ist die Reihenfolge der Finalisierung dann:
  • Finalization Section
  • Class Destructors
  • Finalisierung von Variablen, Konstanten, etc.

(steht übrigens auch nirgends in deiner verlinkten Antwort, dass Class Destruktoren nach allen Finalisierungen laufen)

Gruß,
Sven
Sven
[Free Pascal Compiler Entwickler]
this post is printed on 100% recycled electrons
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.016 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#7

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 25. Mär 2014, 08:17
Danke für die Korrektur mit dem alle. Das sollte eher "nach den finalizations" lauten.

Allerdings stimmt deine Reihenfolge nicht. Der Class destructor läuft ebend nach der Finalisierung der Variablen.

Das steht sowohl im verlinkten Artikel und kannst du ganz einfach nachprüfen.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Der schöne Günther

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

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 25. Mär 2014, 11:01
Das klärt trotzdem meine beiden Fragen nicht:
  1. Warum klappt mein Destruktor (Messagebox, Dateien schreiben) unter Windows 7 immer zuverlässig, unter XP aber nie? Da muss doch noch mehr dahinter stecken...
  2. Was darf ich mir denn nun im Klassendestruktor erlauben? Unter XP sieht es für mich wirklich so aus, als hätte meine Anwendung zu diesem Zeitpunkt nur noch wenige Millisekunden zu leben...

Ich hatte für ein kleines Projekt ein TUserSettings-Singleton. Es sollte durch den Klassendestruktor beim ordentlichen Beenden der Anwendung die Benutzereinstellungen dauerhaft speichern (Registry oder ini-Datei).

Bislang hat mich noch keiner gepackt, geschüttelt und geschrien "Nein! Tu's nicht!".

Geändert von Der schöne Günther (25. Mär 2014 um 11:04 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von stahli
stahli

Registriert seit: 26. Nov 2003
Ort: Halle/Saale
4.343 Beiträge
 
Delphi 11 Alexandria
 
#9

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 25. Mär 2014, 11:29
Hast Du mal getestet, ob Deine eigentliche Aktion "Speichern von Einstellungen" korrekt durchgeführt wird?

Vielleicht liegt Dein Problem ja nur beim Aufruf der MessageBox (dass das XP die nicht mehr anzeigt wenn die Haupt-Anwendung gerade beendet wird).
Stahli
http://www.StahliSoft.de
---
"Jetzt muss ich seh´n, dass ich kein Denkfehler mach...!?" Dittsche (2004)

Geändert von stahli (25. Mär 2014 um 12:18 Uhr)
  Mit Zitat antworten Zitat
TiGü

Registriert seit: 6. Apr 2011
Ort: Berlin
3.070 Beiträge
 
Delphi 10.4 Sydney
 
#10

AW: Ausführung eines Klassendestruktors OS-abhängig?

  Alt 25. Mär 2014, 11:32
Bislang hat mich noch keiner gepackt, geschüttelt und geschrien "Nein! Tu's nicht!".
Drehst du dich manchmal im Büro um?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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