Delphi-PRAXiS
Seite 2 von 3     12 3      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Sonstige Fragen zu Delphi (https://www.delphipraxis.net/19-sonstige-fragen-zu-delphi/)
-   -   Application beenden vor erstem Erzeugen von Form (https://www.delphipraxis.net/168721-application-beenden-vor-erstem-erzeugen-von-form.html)

BUG 6. Jun 2012 20:13

AW: Application beenden vor erstem Erzeugen von Form
 
Zitat:

Zitat von RalfSi (Beitrag 1169731)
Dennoch bleibt mir das mit dem Terminate/Destroy unverständlich (gerade auch, weil ich das Gefühl habe, dass Application.Terminate nichts zur Folge hat, außer Fehlermeldungen).

Ganz einfach: Das Zerstören des Application-Objekts oder Application.terminate beendet das Programm nicht, sondern sondern zerstört nur die Message-Queue.
Es kann aber auch Programme ohne Message-Queue geben, auch wenn das nicht besonders Windows-typisch ist.

Wenn du dich näher mit den Grundlagen (also was unter anderem hinter diesem Objekt steckt) beschäftigen willst, kannst du dir das Win32-Tutorial von Luckie angucken.

jaenicke 6. Jun 2012 20:29

AW: Application beenden vor erstem Erzeugen von Form
 
Zitat:

Zitat von Popov (Beitrag 1169745)
Du solltest nicht immer so negativ denken, vielleicht fehlt dir für den Einsatz einfach nur die Phantasie.

Naja, bei den potentiellen schwerwiegenden Nebenwirkungen für Programm und System fällt mir da in der Tat wenig ein, außer zum Debuggen bei der Entwicklung.

Popov 6. Jun 2012 20:34

AW: Application beenden vor erstem Erzeugen von Form
 
Zum Beispiel.

jaenicke 6. Jun 2012 21:43

AW: Application beenden vor erstem Erzeugen von Form
 
Offene Handles und von der Anwendung genutzter Speicher wird seit Windows NT/Windows 2000 von Windows automatisch freigegeben.
Vorher, bei Windows 9x, gab es das so nicht, da führte Halt ggf. auch dort zu Problemen.

Bei geladenen DLLs und Systemobjekten klappt die automatische Freigabe aber offenbar leider nicht immer, zumindest bis XP (bei Vista/7/8 habe ich noch keine solchen Probleme mehr gehabt), wenn das Programm abgeschossen wird. Das führt meistens nicht zu größeren Problemen, aber es kann auch passieren, dass man Windows irgendwann neustarten muss. Was da genau schief geht, weiß ich nicht, weil ich es mir nie genauer angeschaut habe.

Luckie 6. Jun 2012 21:57

AW: Application beenden vor erstem Erzeugen von Form
 
Wollte gerade sagen, wenn ein Prozess terminiert wird, gibt Windows alle Ressourcen frei und schließt alle offenen Handles. Und über Windows 9x brauchen wir uns wohl nicht mehr unterhalten. ;) Nichts desto trotz bin ich der Meinung, man soll selber den Müll wegräumen, den man angehäuft hat. Hab eich zumindest in meiner Erziehung so gelernt.

BUG 6. Jun 2012 22:58

AW: Application beenden vor erstem Erzeugen von Form
 
Zitat:

Zitat von Luckie (Beitrag 1169757)
Wollte gerade sagen, wenn ein Prozess terminiert wird, gibt Windows alle Ressourcen frei und schließt alle offenen Handles.

Sollte es.

Aber wer weiß, wie Windows 1337 mit Ressourcen umgeht? Oder ReactOS? Oder WINE?
Im besten Fall werden die sich an die API Dokumentation halten.

Also sollte man zumindest dafür sorgen, dass sich zumindest der Code, den man selbst kontrolliert, sich entsprechend der Spezifikation verhält.
Dabei kann er auch auf geringe Abweichung von der Spezifikation in den nicht kontrollierten Komponenten behandeln (vgl. strikte Sender und relaxte Empfänger in Netzwerk-Protokollen).


PS: Das ist allgemein gemeint, also direkt nicht an Luckie gerichtet. Das Zitat ist nur der Aufhänger.

himitsu 7. Jun 2012 08:00

AW: Application beenden vor erstem Erzeugen von Form
 
Die Message-Queue wird nicht zerstört ... sie wird einfach nur nicht mehr abgearbeitet, was Delphi in Application.Run und Application.ProgressMessages macht.

Konsolenanwendungen kommen ohne Message-Queue aus, da sie standardmäßig nichts mit "Fenstern" Machen.

Chemiker 7. Jun 2012 10:25

AW: Application beenden vor erstem Erzeugen von Form
 
Hallo,

Zitat:

Wenn ich feststelle, dass die Datei nicht vorhanden ist, soll CreateForm nicht aufgerufen und das Programm gleich beendet werden.
Was soll das für ein Vorteil bringen, ohne den Benutzer zu informieren, dass noch eine bestimmte Datei fehlt, das Programm ohne weiteren Kommentar zu beenden. Besser ist es doch das Form zu zeigen eine Fehlermeldung anzuzeigen und dann das Programm, ohne Klimmzüge sauber zu beenden.

Bis bald Chemiker

Maya 7. Jun 2012 11:18

AW: Application beenden vor erstem Erzeugen von Form
 
Zitat:

Zitat von Chemiker (Beitrag 1169804)
Hallo,

Zitat:

Wenn ich feststelle, dass die Datei nicht vorhanden ist, soll CreateForm nicht aufgerufen und das Programm gleich beendet werden.
Was soll das für ein Vorteil bringen, ohne den Benutzer zu informieren, dass noch eine bestimmte Datei fehlt, das Programm ohne weiteren Kommentar zu beenden. Besser ist es doch das Form zu zeigen eine Fehlermeldung anzuzeigen und dann das Programm, ohne Klimmzüge sauber zu beenden.

Bis bald Chemiker

Ich möchte für diesen Beitrag einen "Gefällt mir"-Button. :thumb:

Sir Rufo 7. Jun 2012 12:57

AW: Application beenden vor erstem Erzeugen von Form
 
So sollte das sauber sein (unabhängig davon, ob das user-friendly oder sinnvoll ist)
Delphi-Quellcode:
if not SomethingMissing then
begin
  Application.Initialize;
  Application.CreateForm(TfrmMain, frmMain);
  Application.Run;
end;
Denn jetzt verhält sich die Anwendung wie eine Konsolen-Anwendung, wenn die Anfangsbedingung nicht zutrifft.


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:34 Uhr.
Seite 2 von 3     12 3      

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