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 Grund herausfinden, warum PostMessage() nicht funktioniert hat (https://www.delphipraxis.net/158917-grund-herausfinden-warum-postmessage-nicht-funktioniert-hat.html)

s.h.a.r.k 8. Mär 2011 01:31

Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Vorab: von himitsu wurde ich darauf hingewiesen, dass ich doch aufpassen sollte, wenn ich Objektreferenzen via PostMessage() hin und her schicke, da die Nachricht ja nicht ankommen muss. Ich habe es so konzipiert, dass wenn die Nachricht erfolgreich angekomme ist, der gegenüber sich auch um die Freigabe des Objekts kümmern muss. Wenn PostMessager() False liefert gebe ich das Objekt einfach blind im Sender frei.

An dieser Stelle will ich das Ganze etwas besser Differenzieren können. Ich kenne zwei Gründe, warum PostMessage() fehl schlagen kann:
  • Message-Queue des Empfängers ist voll.
  • Handle des Gegenübers existiert nicht.

Interessant für mich wäre nun, wie ich denn zwischen diesen beiden Gründen unterscheiden kann, um entsprechend darauf reagieren zu können.

Wenn es noch mehr Gründe geben sollte, dann wäre es zum einen interessant zu erfahren welche und zum anderen wie ich darauf eingehen kann :)

Luckie 8. Mär 2011 02:00

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Du schickst Objektreferenzen, also Pointer, zwischen Fenstern des selben Prozesses hin und her?

Wäre es nicht sinnvoller mit Ereignissen zu arbeiten?

Ob du ein gültiges Handle hast, kannst du mit der Funktion IsHandle prüfen.

Bernhard Geyer 8. Mär 2011 06:05

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Zitat:

Zitat von s.h.a.r.k (Beitrag 1086674)
Ich kenne zwei Gründe, warum PostMessage() fehl schlagen kann:

Der dritte Grund ist schlecht/fehlerhaft Programmierte SW wie NView. Mit diesen hatten wir schon öfters probleme das einfach User-Messages die im Programm gesendet wurden einfach verschluckt wurden. Vor allem bei WM_COPYDATA pfuschen Hilfsprogramme die sich in jeden Prozess hängen dazwischen.

himitsu 8. Mär 2011 06:29

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
MSDN-Library durchsuchenPostMessage

z.B.
Zitat:

Return Value

Type: BOOL

If the function succeeds, the return value is nonzero.

If the function fails, the return value is zero. To get extended error information, call GetLastError.

Remarks

When a message is blocked by UIPI the last error, retrieved with GetLastError, is set to 5 (access denied).
Wenn False, dann mit GetLastError den Grund auslesen.

s.h.a.r.k 8. Mär 2011 12:32

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
@himitsu: Das kenne ich schon, nur habe ich mir dann auch mal die Fehlerliste angesehen und die ist ja quasi unendlich lang. Was genau für Fehler PostMessage generiert habe ich bisher nicht gefunden. Und entsprechende Situationen simulieren kann ich nicht, da ich nicht weiß, welche Fehler es überhaupt geben kann.

@Luckie: Ja, das mache ich bisher so, da diese Log-Klasse erst dann alles abarbeiten soll, wenn gerade Zeit für die Nachrichten ist. Ich denke, dass so das Programm etwas weniger "blockiert" wird. Will und werde die Log-Klasse aber bald auf eine TThread-Klasse basieren lassen. Habe da aber noch ein paar Probleme mit dem Konzept.

himitsu 8. Mär 2011 12:55

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Wozu mußt du denn ganau wissen, was es für Fehlercodes gibt?

Falls man einige Fehler geziehlt behandeln will, dann kann man die paar Codes auch ausprobieren und sonst ist es nicht wichtig genaue Fehlercodes zu kennen.

Für die Anzeige MSDN-Library durchsuchenGetLastError + Delphi-Referenz durchsuchenSysErrorMessage oder Delphi-Referenz durchsuchenRaiseLastOSError

s.h.a.r.k 8. Mär 2011 18:26

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Existiert ein Handle, ist aber z.B. die Warteschlage der Messages voll, dann brauche ich das Handle nicht aus meiner Log-Instanz entfernen und versuche weiter Nachrichten da hin zu schicken. Existiert das Handle aber gar nicht, dann kann ich es getrost entfernen. Aber vielleicht ist ja SendMessageTimeout() ja was für mich. Muss mir das mal genauer anschauen.

@Luckie: IsHandle finde ich nirgends! Wo soll es das geben?

Luckie 8. Mär 2011 23:03

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Die Funktion habe ich auch nirgends gefunden habe hier wird sie verwendet: http://stackoverflow.com/questions/5...ab-in-parallel

himitsu 9. Mär 2011 05:49

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
SendMessageTimeout ... ich dachte du wolltest nichtblockierend arbeiten?

Blup 9. Mär 2011 06:53

AW: Grund herausfinden, warum PostMessage() nicht funktioniert hat
 
Die Objekte einfach auf einen Stapel legen und den Empfänger per Postmessage informieren, das er dieses abholen soll. Selbst wenn die Nachricht nicht ankommt, kann der Empfänger das Objekt bei der nächsten Nachricht immer noch abholen.


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

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