Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Delphi bringt GetLastError nach raise Exception noch etwas? (https://www.delphipraxis.net/162298-bringt-getlasterror-nach-raise-exception-noch-etwas.html)

QuickAndDirty 16. Aug 2011 17:14

bringt GetLastError nach raise Exception noch etwas?
 
Hallo ,
ich habe das eine ziemlich pauschale Execption welche die VCL intern raised wenn eine Windows Funktion fehlschlagt.

Kann ich in meinem Programm im Except Teil SyserrorMessage(GetlastError) benutzen um den genauen Fehlergrund melden zu können?

Der Try except block kapselt exakt nur diese eine VCL Methode die eben die Windows Funktion aufruft.

Ich will eben vermeiden die VCL zu modifizieren.

jaenicke 16. Aug 2011 17:34

AW: bringt GetLastError nach raise Exception noch etwas?
 
Solange danach keine andere Windows-Funktion aufgerufen wurde, die ebenfalls einen Fehlerstatus setzt, geht das, ja.

himitsu 16. Aug 2011 18:22

AW: bringt GetLastError nach raise Exception noch etwas?
 
Also kein EurekaLog und Co. verwenden, denn die machen ganz viel.

Es kommt auch auf die Exception (Einige machen noch was im Constructor),
dann noch auf die Try-Finally/Except und Prozedurebenen zwischen der Exception und dem Except.

Wie z.B. Speicherfreigaben lokaler Vriablen.


Aber: Da GetLastError nicht verwendet wird, wenn eine Exception geworfen wird, mußt du nur nach dem/den WinAPI-Aufruf(en), welche(r) GetLastError setzen könnten, dieses sofort abfragen und zwischenspeichern.

QuickAndDirty 17. Aug 2011 09:39

AW: bringt GetLastError nach raise Exception noch etwas?
 
Ja ich habe da so einen Cashmechanismus für Stammdaten (wir haben sehr viele stammdaten), Bewegungsdaten werden natürlich live ermittelt...
Das ganze Erfolgt in einem Timer Ereignis.
Delphi-Quellcode:
    Try
      //Timer sperren
      MyTimer.Enabled := False; //der Ruft nur killtimer aus updatetimer auf. aber hier könnte evtl Getlast error auch schon einen Wert haben....:( ok
      RefreshDatasets; //Die Stammdaten neu cachen welche in der loggtabelle Änderungen aufweisen.
      MyTimer.Enabled := True; //<-- hier passiert der Fehler
                                //bzw in der methode Extctrls.TTimer.UpdateTimer;
    except
      on E:Exception do
      begin
        e.message := 'Fehler 67: ' + e.Message+ 
                     #13#10' SysErrorMessage:'+SyserrorMessage(GetlastError);
        MyTimerActive := false;
        raise;
      end;
    end;
UpdateTimer ist in Delphi 7 seltenst dämlich implementiert! Weil die Fehler meldung nur auf Systemen kleiner windows 2000 sinnstiftend ist. Diese Methode möchte ich aber nicht patchen!
Delphi-Quellcode:
procedure TTimer.UpdateTimer;
begin
  KillTimer(FWindowHandle, 1);
  if (FInterval <> 0) and FEnabled and Assigned(FOnTimer) then
    if SetTimer(FWindowHandle, 1, FInterval, nil) = 0 then
      raise EOutOfResources.Create(SNoTimers);
end;

himitsu 17. Aug 2011 12:43

AW: bringt GetLastError nach raise Exception noch etwas?
 
Zitat:

Zitat von QuickAndDirty (Beitrag 1117446)
<-- hier passiert der Fehler

Welcher Fehler?
Wird
Delphi-Quellcode:
EOutOfResources.Create(SNoTimers);
etwa ausgelöst?

QuickAndDirty 17. Aug 2011 13:53

AW: bringt GetLastError nach raise Exception noch etwas?
 
Ja genau der wird ausgelöst ("nicht genügend timer verfügbar")
Und die Fehlermeldung hat mit der Realität nichs zu tun...denn das eigentliche Problem dürfte sein das der Rechner kurz davor mehrfach eingefroren ist...und hinterher neugestartet werden musste..

Der Text ist nicht wirklich aussagekräftig auf Rechnern größer NT4.0
Deswegen will ich zusätzlich die SysErrorMessage haben!

DeddyH 17. Aug 2011 13:55

AW: bringt GetLastError nach raise Exception noch etwas?
 
Zitat:

Zitat von QuickAndDirty (Beitrag 1117528)
Der text ist also nicht wirklich aussage kräftig auf Rechnern größer NT4.0

[OT] Wenn man auch so modernes Zeugs einsetzt... :twisted: (SCNR) [/OT]

QuickAndDirty 17. Aug 2011 14:13

AW: bringt GetLastError nach raise Exception noch etwas?
 
[OT]
Zitat:

Zitat von DeddyH (Beitrag 1117529)
Zitat:

Zitat von QuickAndDirty (Beitrag 1117528)
Der text ist also nicht wirklich aussage kräftig auf Rechnern größer NT4.0

[OT] Wenn man auch so modernes Zeugs einsetzt... :twisted: (SCNR) [/OT]

Wenn man Timer auf Formularen spammen will, kommt man da nicht drum herum.
[/OT]

jaenicke 17. Aug 2011 14:50

AW: bringt GetLastError nach raise Exception noch etwas?
 
Zitat:

Zitat von QuickAndDirty (Beitrag 1117528)
Ja genau der wird ausgelöst ("nicht genügend timer verfügbar")
Und die Fehlermeldung hat mit der Realität nichs zu tun...denn das eigentliche Problem dürfte sein das der Rechner kurz davor mehrfach eingefroren ist...und hinterher neugestartet werden musste..

Doch, das ist genau das Problem. Irgendein Programm schnappt sich da zu viele Handles, und Windows 2000 hat halt nicht so viele zur Verfügung.

Das Problem ist also eher ein konzeptionelles, sei es in diesem oder einem anderen Programm...

QuickAndDirty 17. Aug 2011 15:08

AW: bringt GetLastError nach raise Exception noch etwas?
 
Zitat:

Zitat von jaenicke (Beitrag 1117542)
Zitat:

Zitat von QuickAndDirty (Beitrag 1117528)
Ja genau der wird ausgelöst ("nicht genügend timer verfügbar")
Und die Fehlermeldung hat mit der Realität nichs zu tun...denn das eigentliche Problem dürfte sein das der Rechner kurz davor mehrfach eingefroren ist...und hinterher neugestartet werden musste..

Doch, das ist genau das Problem. Irgendein Programm schnappt sich da zu viele Handles, und Windows 2000 hat halt nicht so viele zur Verfügung.

Das Problem ist also eher ein konzeptionelles, sei es in diesem oder einem anderen Programm...

Ja aber es hat mit der Timer-Beschränkung in den älteren Windows Versionen nichts zu tun. Deswegen ist die Fehlermeldung falsch! Und entweder bekomme ich dort gerade einfach kein Handle...was ja dann eine Problem aller Anwendnungen dieses PCs ist...bzw. einer Anwendung dieses Pcs die handles leckt.
Und das ist wohl in diesem fall auch der fall (Vermutung) oder ich schreibe z.B. wie wild in dem Programm im Arbeitsspeicher herum und kotaminiere die Hwnd variable... &c...
Auf jedenfall wäre es super sinnvoll die richtige Fehlermeldung zu bekommen, statt dieses Standardtextes


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:06 Uhr.
Seite 1 von 2  1 2      

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