Diskuze: Jak vyskočit z blokovaného čtení ? socket tcp
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 3 zpráv z 3.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj,
nějak tvému popisu problému moc nerozumím, možná by bylo nejlepší ukázat kostru kódu na tom, čemu říkáš klient a server, která řeší právě to navazování spojení a posílání dat.
Pak jsou tam pro mě ještě nějaké podivné věci:
Jinak, se sockety se dá pracovat i asynchronně (asynchronní odesílání a přijímání dat), případně se dá zařídit, abys dostával notifikace o stavu určitého socketu. Ale pochybuju, že tyto vymoženosti lze psát rozumně přenositelně (ledaže by existovala nějaká knihovna).
Ahoj, děkuji za odpověď. Ještě bych to zkusil více popsat. Server
poslouchá na TCP portu 10060. Pokud je žádost o spojení, tak spojení
realizuje a do otevřeného socketu pošle specifickým protokolem dotaz
klientovi, aby mu poslal 128 bajtů dat. Klient to přijme, zapracuje s
nějakým jednočipem a vezme těch 128 bajtů dat a pošle je tím specifickým
protokolem na server.
Nelze udělat to, že se potom spojení uzavře, protože ztratím možnost
cokoliv ze serveru poslat klientovi a čekat třeba 60s u nějakého webového
rozhraní na to, abych mohl stisknout tlačítko a poslat klientovi, který
není momentálně připojen, nějaký jiný dotaz specifickým protokolem, tak
to je nesmysl. Není to nějaký bankovní systém nebo něco, kde člověk
může trávit spoustu času a když to náhodou nejde, tak to zkusí za hodinu
znovu. Musí to reagovat obratem.
Klient ten tedy osetvře TCPsocket blokovaný a přejde na fukci read ze socketu a protože je blokovaný, tak tam stojí, dokud mu nepřijdou data socketem. Jenže co se stane, když se spojení rozpadne nebo mi server nepošle žádost do třeba 65s ? Tak client předpokládá, že je spojení špatné a zavolá funkci close socket, ta sice uzavře socket, ale protože čtení je voláno ve svém vlákně a v podstatě to stojí ve volání read, tak se z tohoto volání nedostanu. Tak mně napadlo, že nejdříve bych se měl dostat z toho blokovaného read a potom zavřít socket. Jen netuším jak to provézt. Druhé řešení je udělat to v neblokovaném čtení, potom bych měl kdykoliv po zavolání read ze socketu dostat nějakou hodnotu o počtu přijatých bajtů. Zdroják přikládám. Jirka
Ten zdroják jsem přidal do Máš dlohý zdroják, ale nikdo ho tu nevidím. Tak doufám, že se k němu dostaneš. Jirka
Zobrazeno 3 zpráv z 3.