Java中如何通过DatagramSocket实现UDP通信的入门级教程?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1019个文字,预计阅读时间需要5分钟。
由于DatagramSocket本身不维护连接状态,它只负责将DatagramPacket发送出去或从任意来源接收包。你无法调用socket.getOutputStream()或类似方法——这些在UDP中基本不存在。所有数据都必须封装进DatagramPacket,并指定IP和端口(除非使用connect()进行预设)。
常见错误现象:SocketException: socket closed —— 多线程中没同步关闭;IOException: Message too long —— UDP 单包超 65507 字节(IPv4);收不到包却无报错——防火墙、端口被占、没绑定本地端口或 receive() 前没调用 setSoTimeout() 导致线程永久阻塞。
- 发送方不需要
bind(),但若想接收响应,通常也得绑一个端口(否则系统随机分配,对方难回) - 接收方必须显式
bind()到具体端口,且该端口未被其他进程占用 -
connect()不建立连接,只是限制后续send()只能发给指定地址,并让receive()只接收来自该地址的包(提升安全性,也避免误收)
如何正确构造 DatagramPacket 发送字节数组
DatagramPacket 的构造函数参数顺序容易搞反:是 new DatagramPacket(byte[], length, InetAddress, port),不是“先地址后字节数组”。
本文共计1019个文字,预计阅读时间需要5分钟。
由于DatagramSocket本身不维护连接状态,它只负责将DatagramPacket发送出去或从任意来源接收包。你无法调用socket.getOutputStream()或类似方法——这些在UDP中基本不存在。所有数据都必须封装进DatagramPacket,并指定IP和端口(除非使用connect()进行预设)。
常见错误现象:SocketException: socket closed —— 多线程中没同步关闭;IOException: Message too long —— UDP 单包超 65507 字节(IPv4);收不到包却无报错——防火墙、端口被占、没绑定本地端口或 receive() 前没调用 setSoTimeout() 导致线程永久阻塞。
- 发送方不需要
bind(),但若想接收响应,通常也得绑一个端口(否则系统随机分配,对方难回) - 接收方必须显式
bind()到具体端口,且该端口未被其他进程占用 -
connect()不建立连接,只是限制后续send()只能发给指定地址,并让receive()只接收来自该地址的包(提升安全性,也避免误收)
如何正确构造 DatagramPacket 发送字节数组
DatagramPacket 的构造函数参数顺序容易搞反:是 new DatagramPacket(byte[], length, InetAddress, port),不是“先地址后字节数组”。

