AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Cross-Platform-Entwicklung iOS Indy, Events & IOS wer liegt falsch?
Thema durchsuchen
Ansicht
Themen-Optionen

Indy, Events & IOS wer liegt falsch?

Ein Thema von Mavarik · begonnen am 15. Mai 2013 · letzter Beitrag vom 12. Jan 2015
Antwort Antwort
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.142 Beiträge
 
Delphi 10.3 Rio
 
#1

Indy, Events & IOS wer liegt falsch?

  Alt 15. Mai 2013, 13:36
Hallo Zusammen.

Mir stellt sich gerade die Frage ob Indy, IOS, FM3 den Fehler macht oder
ich...

gegeben sei:

Delphi-Quellcode:
procedure TMyForm.IdTCPClient1Connected(Sender: TObject);
begin
  repeat
    // Mache viel!
  until raushier;
  IdUDPServer1.disconnect;
end;

procedure TMyForm.IdUDPServer1UDPRead(AThread: TIdUDPListenerThread;
  const AData: TIdBytes; ABinding: TIdSocketHandle);
begin
  // Mache so einiges
  IdTCPClient1.Connect;
  Memo1.Lines.Add('Raus hier');
end;
Was ich erwartet habe:
Der UDPServer startet den TCPClienten...
Im Memo steht "Raus hier"
und wenn der OnConnect des Clients kommt wird alles "verarbeitet" und der UDP Server
diskonnected.


Was passiert ist aber:
Der Client Onconnect kommt SOFORT
Der Server Disconnect am ende kann nicht aufgerufen werden, da der Connectcall innerhalb
des UDP Server Threads ist.
Nach einer netten Exception (abgefangen) steht dann im Memo "Raus hier"...

Hättet Ihr es gewusst? Mein Fehler?

Grüsse Mavarik
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#2

AW: Indy, Events & IOS wer liegt falsch?

  Alt 15. Mai 2013, 14:11
Was ist das eigentlich?

[DELPHI]IdUDPServer1.Disconnect;[DELPHI]

Das man auf einem Server ein Disconnect ausführt, setzt normalerweise eine Verbindung voraus. Bei UDP gibt es keine Verbindung ...
Michael Justin
  Mit Zitat antworten Zitat
Benutzerbild von DataCool
DataCool

Registriert seit: 10. Feb 2003
Ort: Lingen
909 Beiträge
 
Delphi 10.3 Rio
 
#3

AW: Indy, Events & IOS wer liegt falsch?

  Alt 15. Mai 2013, 15:01
@Mavarik:
Ich habe zwar den Indy-UDP-Server noch nicht so oft eingesetzt, aber ich bin mir ziemlich sicher das das OnUDPRead
immer wieder von Indy-Listener-Thread aufgerufen wird.
Genauso läuft es beim IdTcpServer und dem "OnExecute" Event.
In der Doku steht dazu auch, das der Code Thread-Safe sein muss und/bzw. Interaktion mit der Gui synchronisiert werden müssen.

Dein Code ist so nicht richtig strukturiert/aufgebaut,
was ist wenn das OnUDPRead-Event ein zweites/xyz mal eintritt bevor der TcpClient seine Arbeit verrichten kann ?
Bei Deinem Code würde der TcpClient nochmals versuchen zu connecten, obwohl er gerade verbunden ist und brav arbeitet.

und anstatt IdUdpServer1.disconnect aufzurufen, wäre es mit IdUdpServer1.Active := false;
Bei einem verbindungslosen Protokoll "besser zu lesen".

Greetz Data
Der Horizont vieler Menschen ist ein Kreis mit Radius Null, und das nennen sie ihren Standpunkt.
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.142 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: Indy, Events & IOS wer liegt falsch?

  Alt 15. Mai 2013, 18:43
Ja stimmt...

Hab das aus dem Kopf geschrieben...

idudpServer1.Active := false;

Natürlich...

Es geht hier auf überhaupt nicht um Thread-Save...

Es geht darum, dass idClient1.Connect die Verarbeitung anhält... Und erst wieder kommt, wenn die OnConnected abgearbeitet ist...
Und nicht das der Event Connect ausgeführt wird und irgendwann später kommt...

Das macht Indy scheinbar schon immer so...

Mavarik
  Mit Zitat antworten Zitat
arnof

Registriert seit: 25. Apr 2013
1.254 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#5

AW: Indy, Events & IOS wer liegt falsch?

  Alt 16. Mai 2013, 09:28
Also ich hatte mal mit den Indy Sachen und IOS experimentiert, und da ging was ich wollte ohne Probleme!

Sogar das Bilder versenden:

Server auf Active:

IdTCPServer1.Active:=True;

der wartet auf die Dinge die dann zu Ihm kommen ....


Der Client:

IdTCPClient.Conntect

-----

was machen (senden)

-----

IdTCPClient.DisConntect

Geändert von arnof (16. Mai 2013 um 09:32 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.142 Beiträge
 
Delphi 10.3 Rio
 
#6

AW: Indy, Events & IOS wer liegt falsch?

  Alt 16. Mai 2013, 12:04
Also ich hatte mal mit den Indy Sachen und IOS experimentiert, und da ging was ich wollte ohne Probleme!
Hast Du eigentlich meine Frage gelesen?
  Mit Zitat antworten Zitat
arnof

Registriert seit: 25. Apr 2013
1.254 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#7

AW: Indy, Events & IOS wer liegt falsch?

  Alt 16. Mai 2013, 16:16
na dann ein zweites mal:

das solltest Du in einen Timer auslagern, sonst kann er mit den Theads durcheinander kommen:

procedure TMyForm.IdUDPServer1UDPRead(AThread: TIdUDPListenerThread;
const AData: TIdBytes; ABinding: TIdSocketHandle);
begin
// Mache so einiges nicht

Timer1.enabled:=True;
end;


procedure TMyForm.Timer1ontimer(Sender ...);
begin
Timer1.enabled:=false; // nur einmal machen
// jetzt bin ich ein eigender thead .....
// Mache so einiges
IdTCPClient1.Connect;
Memo1.Lines.Add('Raus hier');
end;
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.142 Beiträge
 
Delphi 10.3 Rio
 
#8

AW: Indy, Events & IOS wer liegt falsch?

  Alt 16. Mai 2013, 23:04
na dann ein zweites mal:
OK Vergiss einfach diesen Thread!
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.166 Beiträge
 
Delphi 10 Seattle Professional
 
#9

AW: Indy, Events & IOS wer liegt falsch?

  Alt 12. Jan 2015, 10:15
Der Thread liegt schon lange zurück, aber das Problem habe ich ebenfalls. Bei TCP-Verbindung (TIdTCPClient) in einer Firemonkey iOS-App wird OnConnect sofort ausgelöst, noch bevor der Socket verbunden ist. Konnten Sie damals die Lösung für dieses Problem finden?
  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 07:30 Uhr.
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