![]() |
string mit postmessage übermitteln?
hallo,
ich versuche einen string über eine postmessage von eienem thread an mein form zu senden. mit einem integer geht das auch wunderbar. ich wuerde gerne wissen ob das auch mit einem string machbar ist? hab mir schon die msdn angeschaut , da aber nix zu datentypen gefunden :( Richard |
Re: string mit postmessage übermitteln?
Hallo,
Du musst den String in einen LongInt umwandeln, dann sollte es funktionieren:
Delphi-Quellcode:
PostMessage([empfaenger], [command], [wParam], LongInt(PChar(MeinString)));
|
Re: string mit postmessage übermitteln?
ok danke geht ;)
|
Re: string mit postmessage übermitteln?
|
Re: string mit postmessage übermitteln?
Hagens Version ist, wie es gemacht wird.
Man könnte, ausgehend vom Fall, daß Nachrichten nicht ankommen werden, die pointer noch in eine TList eintragen lassen. Diese Liste müßte je nach Programmart ab und wann überprüft werden. Wie das genau gelöst wird hängt jetzt vom Programm ab, ob z.B. der Thread immer laufen soll oder nicht. Wenn er ständig läuft müßte die Liste per CriticalSection gesichert werden, welches das übergeben des Pointers eh überflüßig machen würde. Muß denn unbedingt postMessage statt sendMessage verwendet werden? Bedenke es gibt auch ein SendMessageTimeout, der von einem Thread aus nahezu alle Nachteile von SendMessage aufheben dürfte. |
Re: string mit postmessage übermitteln?
Man kann mit PostMessage durchaus einen Pointer/PChar uebermitteln, solange es nur innerhalb des Adressraums des Programms bleibt.
Versucht man die Adresse zu einem anderen Programm zu schicken, so ist sie dort bedeutungslos, da das andere Programm seinen eigenen Adressraum hat. Der Fehler bei Jens lag daran das die Stringvariable im Threadobjekt enthalten war. Es konnte also prinzipiell vorkommen das der Thread schon beendet war wenn die Message ankam. Der String war dann natuerlich schon dealloziiert und der Pointer zeigte in den Wald. |
AW: string mit postmessage übermitteln?
Da ich vor dem gleiche Problem, kapere ich den Thread einmal.
z.Zt. habe ich folgenden Code (auf das wesentliche gekürzt)
Delphi-Quellcode:
Ich könnte in msg.LParamLo natürlich auch den Index für ein Array of TextMessages übergeben, aber soviel Aufwand für z.Zt 6 Meldungen?
Unit1
cFILEDELETION :string= 'Deletion of Files'+#0; cGETSOURCEFILES :string= 'get source Files'+#0; cGETTARGETFILES :string= 'get target Files'+#0; Unit2 ... sendmessage(FReceiver,CM_Start2,0,longint(pchar(CGETSOURCEFILES))); .... UnitMain procedure TForm1.CMStart2(var msg:TMessage); var mm : pchar; begin mm:=pchar(msg.LParamLo); self.StatusBar1.Panels[3].Text:=mm; {---- hier macht es puff mit einer Zugriffsverletzung} end; Was ist da nicht in Ordnung? (sowohl postmessage als auch sendmessage funktionieren nicht!) Gruß K-H |
AW: string mit postmessage übermitteln?
Hilft das weiter?
![]() Ansonsten würd' ich das probieren:
Delphi-Quellcode:
self.StatusBar1.Panels[3].Text := StrPas(mm);
|
AW: string mit postmessage übermitteln?
Leider nicht,
das Strickmuster ist das gleiche wobei txt noch eine lokale variable ist, daß sollte tödlich sein. und StrPas hat auch keine Besserung gebracht. Es kommt irgendein Adresskrüppel in
Delphi-Quellcode:
an.
CMStart2
Gruß K-H Edith: :wall: wenn man genau hinsieht erkennt man auch den Unterschied zwischen ,
Delphi-Quellcode:
und
msg.LParam
Delphi-Quellcode:
!!?*/!#***Codevervollständigung!
msg.LParamLo
Ja ich weiß, der Fehler sitzt immer vor der Tastatur. Gruß K-H |
AW: string mit postmessage übermitteln?
PChar ist doch ein 0-terminierter String. Du übergibst aber bereist eine Constante, die mit #0 endet. Ist das eventuell doppeltgemoppelt?
Also eher so?
Delphi-Quellcode:
oder so?
cGETSOURCEFILES :string = 'get source Files';
... sendmessage(FReceiver,CM_Start2,0,longint(pchar(CGETSOURCEFILES)));
Delphi-Quellcode:
cGETSOURCEFILES :string = 'get source Files' + #0;
... sendmessage(FReceiver,CM_Start2,0,longint(CGETSOURCEFILES)); |
AW: string mit postmessage übermitteln?
Geht das an ein anderes Programm?
Wenn ja, dann nicht PChar, sondern PAnsiChar oder PWideChar verwendent. LongInt() ... in Blick richtung 64 Bit, solltest du hier besser auch die richtigen Typen verwenden. Für Messages gibt es die Typen LPARAM, WPARAM und LRESULT. |
AW: string mit postmessage übermitteln?
@nahpets
das
Delphi-Quellcode:
ist nur um sicher zu gehen, das auch wirklich eine Null da steht, ich traue
+#0
Delphi-Quellcode:
da nicht so recht.
PChar
@himitsu Nö kein anderes Programm, aber der Hinweis mit dem Typ: Danke! Aber mal zurück gefragt, ist PChar nicht der richtige Typ wenn ich nicht weiß ob der String mit 8 oder 16 Bit Chars aufgebaut wird? Gruß K-H |
AW: string mit postmessage übermitteln?
Wenn Du an 'nen String 'ne #0 dranhängst, dann hast Du sie doch schon. Wenn Du dann PChar nicht traust, dass es einen String in einen null-terminierte Zeichenfolge umwandelt, kannst Du doch PChar weglassen ;-)
Habe mal in meinen Quelltexten gesucht, dort sieht das immer (sinngemäß) so aus:
Delphi-Quellcode:
Konstanten werden ohne + #0 deklariert.
sendmessage(FReceiver,CM_Start2,0,DWord(PAnsiChar(CGETSOURCEFILES)));
Und das Ganze funktioniert schon seit Jahren problemlos. Bitte mal LongInt durch DWord ersetzen, wir brauchen hier keinen Typen, der auch negative Werte zulässt. Und bitte statt PChar mal PAnsiChar nehmen. Habe halt nur Delphi 7, ob's bei anderen Versionen anders sein muss, weiß ich nicht. |
AW: string mit postmessage übermitteln?
OK die Null spar ich mir, aber das PAnsiChar?
falls ich dann doch einmal einen Unicodefähigen Compiler nutzen sollte, dann liegen doch wohl auch die Constanten als 16Bit Chars vor, und da sollte PAnsiChar doch eher für eine "Verkürzung sorgen? Gruß K-H |
AW: string mit postmessage übermitteln?
Ratet mal, wie intern ein LongString (String, AnsiString, UnicodeString) und auch WideString aufgebaut sind .... Verwaltungsdaten+DemText+#0#0 :stupid:
|
AW: string mit postmessage übermitteln?
Zitat:
Heißt das dann, dass hierbei
Delphi-Quellcode:
wir eigentlich ein
cGETSOURCEFILES :string= 'get source Files'+#0;
Delphi-Quellcode:
haben und mit PChar dann noch ein #0 dazuhängen und damit dann ein
'get source Files'#0#0#0
Delphi-Quellcode:
dabei rauskommt?
'get source Files'#0#0#0#0
Oder kapiert der Kompiler das und macht es von alleine "richtig"? Und wenn wir schon PChar-Konstanten haben möchten, dann können wir die doch eigentlich auch als PChar deklarieren:
Delphi-Quellcode:
Mein olles Delphi 7 frisst das jedenfalls. Oder denke ich jetzt hier um zuviele, altbackenen, Ecken?
cFILEDELETION : PChar = 'Deletion of Files';
cGETSOURCEFILES : PChar = 'get source Files'; cGETTARGETFILES : PChar = 'get target Files'; |
AW: string mit postmessage übermitteln?
Ich meine mich zu erinnern, daß Strings (abgesehen von den Shortstrings) eigentlich aufgemotze PChars sein sollen, aber da ich diesen #0Trailer nach Möglichkeit ignoriere - wofür gibt es die Länge?- gerät das immer wieder in Vergessenheit.
Warum sollte ich in einem Delphi-Programm Konstanten denn als PChar deklarieren? Aber im Prinzip hast Du recht, da eh nur die Adresse weiter gereicht wird, kann man's auch gleich richtig machen. Gruß K-H |
AW: string mit postmessage übermitteln?
Nein, es sind keine aufgekotzten PChars.
Es sind aufgemotzte dynamische Char-Arrays.
Delphi-Quellcode:
array of char
Delphi verwendet die Längenangabe, aber als Kompatibilität zeigt der interne Pointer nicht auf den Anfang der Steuerdaten, sondern dahinter, und hinter dem letzten Zeichen werden im Speicher noch zwei #0 abgelegt. So kann der String-Pointer direkt als PChar verwendet werden (zum Lesen). Der ShortString (der String aus Delphi 1 und davor) ist ein Record, mit einem LängenByte und drauf folgenden Chars. Char 1 war auf BytePosition 1 und das Längenbyte auf BytePosition 0 ... darum sind Strings auch mit 1 indexiert, obwohl dort das erste Char auf BytePosition 0 liegt und die Steuerdaten (Länge, Refernzzählung und seit 2009 auch CharSize und CodePage) davor liegen. |
AW: string mit postmessage übermitteln?
Zitat:
Delphi-Quellcode:
const xxx = 'abc'; // untypisiert
const yyy: string = 'abc'; // typisiert PChar(xxx) // compilerabhängig PAnsiChar(xxx) // immer ein Ansistring PWideChar(xxx) // immer ein Unicodestring PChar(yyy) // immer richtig PAnsiChar(yyy) // kann funktionieren (vor 2009), aber muß es nicht PWideChar(yyy) // kann funktionieren (ab 2009), aber muß es nicht |
AW: Re: string mit postmessage übermitteln?
Zitat:
Delphi-Quellcode:
noch immer verwendbar?
PostMessage([empfaenger], [command], [wParam], LongInt(PChar(MeinString)));
Was genau hat negaH denn da besser gemacht und warum sollte man das oben nicht verwenden? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:03 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-2025 by Thomas Breitkreuz