Non-blocking TCP/IP SocketChannel
s and Selector
in NIO help me to handle many TCP/IP connections with small number of threads. But how about UDP DatagramChannels
? (I must admit that I'm not very familiar with UDP.)
UDP send operations don't seem to block even if the DatagramChannel
is not operating in blocking mode. Is there really a case where DatagramSocket.send(DatagramPacket)
blocks due to congestion or something similar? I'm really curious if there's such a case and what the possible cases exist in a production environment.
If DatagramSocket.send(DatagramPacket)
doesn't actually block and I am not going to use a connected DatagramSocket
and bind to only one port, is there no advantage of using non-blocking mode with DatagramChannel
and Selector
?