AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi AnsiString an Threads schicken (PostThreadMessage)
Thema durchsuchen
Ansicht
Themen-Optionen

AnsiString an Threads schicken (PostThreadMessage)

Ein Thema von AJ_Oldendorf · begonnen am 10. Mai 2012 · letzter Beitrag vom 16. Mai 2012
Antwort Antwort
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.342 Beiträge
 
Delphi 12 Athens
 
#1

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 10. Mai 2012, 16:53
Wo kommt der PAnsiString-Parameter für SchickeNachricht her?

Strings verfügen über eine Referenzzählung, da kann der Strinng schnell mal verschwinden, selbst wenn er es nicht sollte, weil irgendwo noch ein Pointer drauf zeigt.
Genauso kann man über sein wildes rumgepointere die Speicherverwaltung auch andersrum zerschießen und der String würde nie freigegeben.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
AJ_Oldendorf

Registriert seit: 12. Jun 2009
427 Beiträge
 
Delphi 12 Athens
 
#2

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 10. Mai 2012, 17:04
Hier ein Ausschnitt, wie der PAnsiString erzeugt wird:

Delphi-Quellcode:
function ErzeugeNachricht(InMsg : PAnsiString) : Boolean;
var
  aStr : String[4];
begin
  Result := True;
  try
    SetLength(InMsg^, 5);
    aStr := '100';
    Move (aStr[1], InMsg^[1], 3);
  except
    Result := False;
  end;
end;


Var
  MyMsg : AnsiString;
...

ErzeugeNachricht(@MyMsg);
SchickeNachricht(@MyMsg);
Hoffe habe nix übersehen, passe den Quelltext hier manuell bisschen an, weil es sonst zu viel wäre zum zeigen
Gruß
Alex
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.342 Beiträge
 
Delphi 12 Athens
 
#3

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 10. Mai 2012, 18:24
Ich würde nun auch noch fragen, wo der Parameter für ErzeugeNachricht herkommt.

Aber warum sind diese Parameter denn als Pointer ausgelegt?

Wenn InMsg vor ErzeugeNachricht weniger als 5 Zeichen enthält, dann sind die letzten 1-2 Zeichen undefiniert.

Und was soll das Try-Except darin?
Rechnest du etwa fest mit Problemen?
(solange der übergebene Pointer OK ist, dann wird nichts passieren
und wenn was passiert, dann ist die Chance recht groß, daß du dir dein komplettes Programm zerschießt, auf was mit einem billigen False nicht angemessen reagiert würde, da danach eventuell nicht mehr läuft)

PS: Auch PostMessage hat ein Result.



Wofür soll das denn nun genutzt werden und wie viel, bzw. wie oft, wird was versendet?
Hoffentlich nicht prozessübergreifend oder über Modulgrenzen (EXE/DLL<>DLL) hinweg.


Ja, es mag vielleicht funktionieren, aber je nach Anwendungsfall gibt es bestimmt/eventuell auch andere/bessere/passendere Möglichkeiten.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (10. Mai 2012 um 18:36 Uhr)
  Mit Zitat antworten Zitat
AJ_Oldendorf

Registriert seit: 12. Jun 2009
427 Beiträge
 
Delphi 12 Athens
 
#4

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 11. Mai 2012, 16:20
Hi,
wo die Variable für ErzeugeNachricht herkommt, ist doch dargestellt

Delphi-Quellcode:
Var
  MyMsg : AnsiString;
...

ErzeugeNachricht(@MyMsg);
Zum Beispiel könnte der Aufruf durch ein Button Klick kommen.

Zitat:
Wenn InMsg vor ErzeugeNachricht weniger als 5 Zeichen enthält, dann sind die letzten 1-2 Zeichen undefiniert.
Das stimmt. Habe den Code nur "zusammen kopiert" und diese Stelle nicht richtig angepasst gehabt. Ist also Zufall das es da so steht.

Das Try except habe ich einfach nur zur Sicherheit drum gemacht. Könnte man natürlich auch weglassen.

Die Anwendung arbeitet ohne DLL's, also diese Aufrufe sind nur innerhalb der Anwendung.
Ich kann leider nicht zur sehr ins Detail gehen weil diese Anwendung bei und auf Arbeit entwickelt wurde und deswegen kann ich auch nicht den ganzen Code darstellen. Ich versuche es aber so gut es geht zu beschreiben.
Wir arbeiten mit Nachrichten wie ihr schon gesehen habt. Es gibt ein Hauptthread der die empfangenen Nachrichten auswertet und an die entsprechenden "Unterthreads" weiterleitet. Dies geschieht sehr oft im Programm weil die Kommunikation nur über dieses "Message-Konstrukt" arbeitet (also wird sehr oft benutzt).
Das Konstrukt für das Schicken und Empfangen der Nachrichten ist das von mir beschriebene. Ich sage auch nicht, dass dies die ultimative Lösung wäre, deswegen habe ich ja hier nachgefragt und würde gerne ein paar Anregungen sammeln, wie man sowas auch noch lösen könnte. Ich bin mir auch nicht ganz sicher ob diese beschriebe Lösung, nicht den Speicher ordentlich "framentiert"?!

Viele Grüße
Alex
  Mit Zitat antworten Zitat
AJ_Oldendorf

Registriert seit: 12. Jun 2009
427 Beiträge
 
Delphi 12 Athens
 
#5

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 15. Mai 2012, 16:06
Noch irgendwelche Anregungen bzgl. Speicherfragmentierung bzw. wird der Speicher durch das obere Konstrukt unnötig fragmentiert?!
Das mit dem TSimpleEvent und der ThreadList habe ich mir mal angeguckt. Muss ich mal versuchen umzusetzen in einzelnen Bereichen. Weiß aber nicht, ob ich da wirklich eine "Verbesserung" oder ähnliches feststellen kann. Sehe wahrscheinlich nur, dass es genauso geht oder?!

Gruß
Alex
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#6

AW: AnsiString an Threads schicken (PostThreadMessage)

  Alt 16. Mai 2012, 08:51
Noch irgendwelche Anregungen bzgl. Speicherfragmentierung
Deine bisherige Vorgehensweise ist fehlerhaft (Siehe Beitrag #4).
Unter gewissen Umständen greift dein Thread auf ungültigen Speicher zu.
Ob dein Code funktioniert hängt mehr oder weniger vom Zufall ab.

In folgendem Demo
http://www.delphipraxis.net/168253-s...e-threads.html
kannst du Dir anschauen, wie man einen AnsiString (oder beliebige Daten) einem Thread zur Verarbeitung übergeben kann.
Andreas
  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 10:40 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