在通用的以太网(Ethernet)构架下,计算机于计算机之间的数据交换都是通过交换机来完成的。如果一份数据需要被传送给多个接收者,在使用TCP/IP连接的情况下,数据发送者需要向交换机发送N 个同样的拷贝,而交换机则负责将这N 个拷 贝分发给所有的接收者;
在使用UDP 数据广播的情况下,数据发送者只需要向交换机发送一个拷贝,交换机负责将这个信息制作N 个拷贝发送给所有的机器。在这种情况下,使用TCP/IP连接会大大的增加网络的负担。在一个普通局域网络中,可以认为由于网络状况较差而造成数据丢失的可能性比较小,而利用UDP 数据广播进行 数据交换能够大幅度减轻网络的负担 。
UDP数据广播核心类:
MulticastSocke
tDatagramPacket
广播发送
public class MulticastDemo {
public static void main(String[] args) throws IOException {
String msg = "本周五下午举办第一次班级过活动,望广大童鞋积极参加,相互转告!!!!";
//创建组播地址对象
InetAddress ip = InetAddress.getByName("228.5.6.7");
//创建数据广播通道对象
MulticastSocket ms = new MulticastSocket();
//将组播地址加入网络通道中
ms.joinGroup(ip);
//将消息内容打包成数据报包
DatagramPacket dp = new DatagramPacket(msg.getBytes(),0, msg.getBytes().length, ip, 6789);
//发送数据广播
ms.send(dp);
ms.close();
}
}
广播接收
public class MulticastDemo_Receiver {
public static void main(String[] args) throws IOException {
InetAddress ip = InetAddress.getByName("228.5.6.7");
MulticastSocket ms = new MulticastSocket(6789);
//将组播地址加入网络通道中
ms.joinGroup(ip);
byte[] b = new byte[1024];
//将消息内容打包成数据报包
DatagramPacket dp = new DatagramPacket(b,b.length);
ms.receive(dp);
String s = new String(dp.getData(),0,dp.getLength());
System.out.println(s);
}
}