Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-07-2007, 15:27   #1
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
[JAVA] datagram socket - lunghezza massima payload

ciao ragazzi, ho cercato in lungo e in largo ma non sono riuscito a risolvere questo problema...

la lunghezza massima teorica del payload di un pacchetto udp è ((2^16 - 1) - 8).

Ma se io in Java creo un DatagramSocket e faccio il send di un DatagramPacket passandogli un byte[] di lunghezza ((2^16 - 1) - 8) ottengo una SocketException perchè il pacchetto supera la lunghezza massima ammissibile ("The message is larger than the maximum supported by the underlying transport: Datagram send failed"). La lunghezza massima ammessa è ((2^16 - 1) - 8) - 20. Perchè????

Da notare inoltre come la documentazione del jdk1.6 non indichi che il metodo send può lanciare una SocketException!!!

grazie a tutti per le risposte
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 15:52   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
La lunghezza massima ammessa è ((2^16 - 1) - 8) - 20. Perchè????
8 byte per l'header UDP e 20 byte per l'header IP. Il pacchetto IP contiene il pacchetto UDP, infatti.


EDIT:
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
Da notare inoltre come la documentazione del jdk1.6 non indichi che il metodo send può lanciare una SocketException!!!
Ma indica chiaramente che può lanciare IOException. E infatti SocketException deriva da IOException.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)

Ultima modifica di andbin : 11-07-2007 alle 15:57.
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 15:57   #3
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
cioè mi stai dicendo che l'errore è scatenato quando costruisco il pacchetto IP?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 15:59   #4
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
E' difficile che la documentazione prenda un abbaglio sulle eccezioni rilasciate. E' generata automaticamente a partire dal codice: se throws quello, throws pure la documentazione. Nel caso specifico, SocketException è una IOException, dunque rientra tra quelle che la documentazione dichiara come rilasciabili dal metodo send di DatagramSocket.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 16:00   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Perché 20 (o più) byte sono per l'header IP.

Comunque i pacchetti UDP sono solitamente pacchetti molto piccoli. Quindi utilizzare la massima lunghezza del pacchetto UDP è sconsigliabile, anche perché aumenta la probabilità di errore.
Inoltre se il tuo pacchetto IP supera la MTU delle reti da cui passa verrà segmentato.
L'MTU di una rete classica è di 1500 byte (headers + dati), quindi fai i tuoi conti
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 16:03   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da mad_hhatter Guarda i messaggi
cioè mi stai dicendo che l'errore è scatenato quando costruisco il pacchetto IP?
No, non sei tu che crei il pacchetto IP. Il tuo payload byte[] viene messo in un pacchetto UDP che a sua volta viene poi messo in un pacchetto IP che a sua volta ecc..... tutto secondo il modello OSI.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 16:06   #7
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
grazie a tutti
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2007, 16:07   #8
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da andbin Guarda i messaggi
No, non sei tu che crei il pacchetto IP. Il tuo payload byte[] viene messo in un pacchetto UDP che a sua volta viene poi messo in un pacchetto IP che a sua volta ecc..... tutto secondo il modello OSI.
si, lo so, per costruisco intendevo "quando il mio sistema costruisce..."
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Il Senato statunitense vorrebbe prolunga...
Leica aggiorna lo Store & Galerie Mi...
Artemis II: risolto il problema al razzo...
Hyundai e Kia investono in Qnovo: ottimi...
iPhone 17e sbarca su Amazon (con consegn...
Aptera prossima alla produzione in serie...
Amazon svela le protagoniste della serie...
Nuovi Apple MacBook Pro con M5 Pro e M5 ...
Wind Tre sceglie Ericsson per modernizza...
Il conflitto in Medio Oriente manda in f...
Le soluzioni di Google Cloud per portare...
OPPO e MediaTek: l'intelligenza artifici...
Dopo i cheater, Activision si scaglia co...
'Super-uomo' o incubo tecnologico? Cosa ...
Arriva la Blade Battery 2.0 di BYD, 1.00...
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: 23:58.


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