TCP 协议在两端的Socket之间虚拟了一条链路,UDP协议则没有这么麻烦,两端的Socket只是发送、接收数据报的对象,所以UDP服务器没有并发机制,只需要建立一个数据输入队列就可以。UDP协议数据报传输大小限制在64KB下。
一、DatagramSocket、DatagramPacket
用法如下:
//接收数据 byte[] buffer = new byte[4096]; DatagramSocket socket = null; DatagramPacket packet = new DatagramPacket(buffer,buffer.length); try { socket = new DatagramSocket(30000); socket.receive(packet); System.out.println(packet.getData() == buffer); }catch (Exception e){ e.printStackTrace(); }
//发送数据 byte[] send = new byte[1024]; DatagramPacket sendPacket = new DatagramPacket(send,send.length,packet.getSocketAddress()); try{ socket.send(sendPacket); }catch (Exception e){ e.printStackTrace(); }
这就是最基本的用法,仅作简单了解。
二、MulticastSocket
这个Socket可以将数据报以广播的方式发送到多个客户端
IP协议中为多点广播提供的特殊IP地址范围为224.0.0.0至239.255.255.255。
用法:
try{ //创建指定端口的多点广播socket,以用于接收数据 MulticastSocket socket1 = new MulticastSocket(30000); //创建多点广播IP地址 InetAddress broadcastAddress = InetAddress.getByName("230.0.0.1"); //将该Socket加入指定的多点广播IP地址,每个多点广播IP地址都是一个目标主机组。 socket1.joinGroup(broadcastAddress); //设置本socket发送的数据报会被回送到自身 socket1.setLoopbackMode(false); socket1.send(new DatagramPacket(new byte[1024],1024)); socket1.receive(new DatagramPacket(new byte[1024],1024)); }catch (Exception e){ e.printStackTrace(); }
多点广播socket是DatagramSocket的子类,仅作这些了解,详细的内容在使用中再深入了解。