UDP多线程实现发送和接收消息在同一个界面。

package UDP;

import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.util.Scanner;

public class Demo03 {
public static void main(String[] args) {
new Receive().start();
new Send().start();
}
}

class Receive extends Thread {
public void run() {
try {
// 创建socket相当于创建码头,指定端口号
DatagramSocket socket1 = new DatagramSocket(6666);
// 创建Packet相当于集装箱
DatagramPacket packet1 = new DatagramPacket(new byte[1024], 1024);
while (true) {

// 接收数据:接货
socket1.receive(packet1);
// 获取数据(获取到所有的字节个数)
byte[] arr = packet1.getData();
int len = packet1.getLength();// 获取有效的字节个数
String ip = packet1.getAddress().getHostAddress();// 获取ip地址
int port = packet1.getPort();// 获取端口号
System.out.println(ip + ":" + port + ":" + new String(arr, 0, len));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}

class Send extends Thread {
public void run() {
Scanner sc = new Scanner(System.in);
// 创建码头
DatagramSocket socket;
try {
socket = new DatagramSocket();
while (true) {
// 获取到键盘录入的数据
String line = sc.nextLine();
// 判断啥时候退出
if ("quit".equals(line)) {
break;
}
// 创建集装箱
DatagramPacket packet = new DatagramPacket(line.getBytes(), line.getBytes().length,
InetAddress.getByName("127.0.0.1"), 6666);
// 将数据发出去:发货
// 发货,将数据发送出去
socket.send(packet);
// 关闭码头
// socket.close();
}
} catch (Exception e) {
e.printStackTrace();
}

}
}

 

 

 

 

 

 

 

 

posted @   一块  阅读(721)  评论(0编辑  收藏  举报
编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
点击右上角即可分享
微信分享提示