Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-09-2007, 18:32   #1
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
[JAVA] Socket che si chiudono troppo in fretta

Ciao,

sto sviluppando una semplice applicazione in rete e mi trovo davanti ad un problema.

Ho un Server che gestisce delle connessioni via Socket a dei client dall'altra parte della rete col classico modello "ad ogni connessione in arrivo fai partire un thread che gestisce quella connessione" .

La trasmissione avviene in questo modo :

1 . Connessione da parte del client
2. Il server crea il thread e manda una stringa di testo al client
3. Il client riceve la stringa, ci lavora dietro e manda una risposta al server
4. Il server riceve la risposta.

A questo punto entrambi (sia il thread del server che il client) terminano. Il problema è che spesso (quasi sempre) il client termina prima del server e questo sembra comportare la chiusura della connessione stabilita tramite il Socket col risultato che ,nel tentativo di leggere la stringa inviata dal client, il server lancia una IOException.

Così ho provato a mettere una:

Thread.sleep(100);

alla fine del client per fargli aspettare un pochino prima di chiudersi in modo che la comunicazione col server non venga interrotta e in effetti funziona. Il server riceve correttamente e poi tutto viene chiuso senza problemi.

Questo però ,dopotutto, non mi sembra per niente un workaround elegante, sia perchè esteticamente non è per niente bello ,sia perchè niente mi dice che, col sistema sotto sforzo o rete intasata, il server non richieda più di 100 millisecondi per completare la raccolta dei dati.

Che si può fare?

Grazie

Ciao
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 20:02   #2
pisto
 
Messaggi: n/a
dici che aiuterebbe chiudere , dopo aver mandato la stringa, dal lato client l'InputStream, e da lato server, ricevuta la stringa, l'InputStream? così la chisura viene fatta in due momenti (diversamente da socket.close()). il tcp supporta questa chiusura parziale.
  Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 20:12   #3
AnonimoVeneziano
Senior Member
 
L'Avatar di AnonimoVeneziano
 
Iscritto dal: Aug 2001
Città: San Francisco, CA, USA
Messaggi: 13827
Quote:
Originariamente inviato da pisto Guarda i messaggi
dici che aiuterebbe chiudere , dopo aver mandato la stringa, dal lato client l'InputStream, e da lato server, ricevuta la stringa, l'InputStream? così la chisura viene fatta in due momenti (diversamente da socket.close()). il tcp supporta questa chiusura parziale.
Mmm, non credo di aver capito bene che intendi. Il problema è che io la socket.close() nel client posso anche non metterla, che tanto nel momento in cui il client ha finito di mandare la sua ultima stringa (il messaggio di risposta al server) arriva in fondo al main() e si chiude portandosi dietro con se anche il socket. Nel momento in cui il socket si chiude, dall'altra parte (nel server che riceve i caratteri dal client tramite un ciclo di DataInputStream.readChar()) viene lanciata una IOException e non riceve il messaggio.

Credo che chiudere parzialmente la stream con "shutdownInput()" o "shutdownOutput()" (se ho capito bene quello che intendevi) sia indifferente, perchè tanto alla fine , una volta che il client arriva alla fine del main termina e siamo punto a capo
__________________
GPU Compiler Engineer
AnonimoVeneziano è offline   Rispondi citando il messaggio o parte di esso
Old 28-09-2007, 12:51   #4
Angus
Senior Member
 
L'Avatar di Angus
 
Iscritto dal: Dec 2001
Città: Milano
Messaggi: 545
Non so se hai già risolto, ma se puoi agire a livello del protocollo applicativo allora puoi aggiungere un altro step secondo il famoso algoritmo della raccomandata A/R:

1. Il client stabilisce una connessione col server
2. Il server dispone un thread in attesa dei dati
3. Il client manda i dati e si mette a sua volta in attesa sul canale di ritorno
4. Il server riceve i dati e comunica sul canale di ritorno la ricezione avvenuta
5. Il client riceve la "ricevuta di ritorno" e finalmente chiude la connessione
__________________
Angus the Hunter @ Realm of magic | Angus Young @ Batracer
°SetiEmperor°| Ninja Technologies
{ qualunque cosa sia, è veloce e fa male (cit.) }
Angus è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
I 2 portatili migliori di tutta Amazon: ...
Tornano le offerte sui Kindle base, vers...
NVIDIA App si aggiorna: arriva DLSS 4.5 ...
Claude Code: il codice sorgente esposto ...
Recensione POCO X8 Pro: è lui lo ...
Il primo dissipatore a liquido di Noctua...
Opera Neon abilita il protocollo MCP: l'...
Dyson Clean+Wash Hygiene: lava e pulisce...
NVIDIA investe 2 miliardi in Marvell: pa...
Le GPU come garanzia bancaria: CoreWeave...
KeeneticOS si aggiorna alla versione 5: ...
Regno Unito avvia indagine su Microsoft:...
Disney vuole comprare Epic Games e Fortn...
ASUS ROG Crosshair X870E Glacial: il nuo...
Samsung Galaxy Watch 9 si avvicina al la...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 06:51.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v