上一个demo中只能使用一次就关闭了,现实中我们希望它能持续提供服务。所以我们需要改进。
发送方:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
/**
* @author zhoutian
* @date 2019/6/16 15:41
*/
public class UDPSend2 {
public static void main(String[] args) throws IOException {
// 创建一个UD套字节对象
DatagramSocket ds = new DatagramSocket();
// 创建一个数据报包对象
DatagramPacket dp;
String data;
while (true){
// 键盘录入数据
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
data = br.readLine();
if(data != null){
dp = new DatagramPacket(data.getBytes(),0,data.length(),InetAddress.getByName("127.0.0.1"),10000);
// 发送
ds.send(dp);
}
}
}
}
接收方:
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
/**
* @author zhoutian
* @date 2019/6/16 15:41
*/
public class UDPReceive2 {
public static void main(String[] args) throws IOException {
// 创建一个UD套字节对象
DatagramSocket ds = new DatagramSocket(10000, InetAddress.getByName("127.0.0.1"));
// 调用接收,接收数据,你必须准备好自己的麻袋,dp就像是哪个麻袋
byte [] byff;
DatagramPacket dp;
// 利用死循环来让服务端持续提供服务,它不会因为死循环而宕机吗?,
while (true){
byff = new byte[1024];
dp = new DatagramPacket(byff,0,byff.length);
//不会,因为receive()是一个阻塞的方法,它和多线程中的wait()/notify()方法一样,只有有请求过来,才能将它唤醒,继续往下执行。
ds.receive(dp);
//打印接收到的数据,
String ip = dp.getAddress().getHostAddress();
int port = dp.getPort();
byte[] data = dp.getData();
System.out.println("ip:" + ip+ "\nport:" + port+ "\ndata:" + new String(data));
}
}
}
我们用循环让程序可以持续提供服务了,这很棒。但是,当有多个发送方同时发送时,会发生什么?下一篇在讲。
我们相信程序永远都可以变得更好,就像我们可以变得更优秀一样。