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
Der schöne Günther

Registriert seit: 6. Mär 2013
6.190 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.039 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.190 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?
Angehängte Grafiken
Dateityp: png Unbenannt.png (11,9 KB, 24x aufgerufen)

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.039 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
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 23:09 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 by Thomas Breitkreuz