

新闻资讯
技术学院C#中UDP通信主要使用UdpClient类,发送端无需绑定端口,接收端必须绑定;推荐异步ReceiveAsync避免阻塞,注意防火墙、MTU限制(建议≤1400字节)及线程安全。
在 C# 中实现 UDP 通信主要靠 UdpClient 类,它封装了底层 socket 操作,使用简单、适合无连接、低延迟场景(如局域网设备发现、实时音视频辅助信令、游戏心跳包等)。
发送端不需要绑定端口,直接构造 UdpClient 后调用 Send() 即可:
示例:
var client = new UdpClient();
var data = Encoding.UTF8.GetBytes("Hello from UDP sender!");
client.Send(data, data.Length, "127.0.0.1", 8080);
client.Close(); // 发完及时释放
接收端必须绑定本地端口(new UdpClient(8080) 或 client.Client.Bind()),再用 Receive() 阻塞等待数据:
Receive() 返回接收到的字节数组,并通过 ref IPEndPoint 输出发送方地址try/catch 处理 SocketException(如端口被占、权限不足)client.Available > 0 判断是否有数据示例:
using var server = new UdpClient(8080); IPEndPoint remote = null; while (true) { try { var data = server.Receive(ref remote); string msg = Encoding.UTF8.GetString(data); Console.WriteLine($"[{remote}] {msg}"); } catch (SocketException ex) when (ex.SocketErrorCode == SocketError.Interrupted) { break; // 如关闭时触发 } }
生产环境不建议用 Receive() 阻塞主线程。更稳妥的方式是用异步方法:
ReceiveAsync() 返回 ValueTask,支持 awaitUdpReceiveResult 包含 Buffer、RemoteEndPoint,语义清晰CancellationToken 可安全取消监听简写示例:
async Task ListenLoop(UdpClient client, CancellationToken ct)
{
while (!ct.IsCancellationRequested)
{
var result = await client.ReceiveAsync(ct);
string msg = Encoding.UTF8.GetString(result.Buffer);
Console.WriteLine($"← {result.RemoteEndPoint}: {msg}");
}
}
UDP 是无连接协议,C# 的 UdpClient 虽易用,但几个细节容易踩坑:
EnableBroadcast = true
Send() 建议不超过 64KB(实际受 MTU 限制,通常 ≤1400 字节更稳妥)UdpClient 实例是线程安全的,但 ReceiveAsync() 不允许多个并发调用基本上就这些。UDP 本身不复杂,但可靠性和边界处理得靠你自己补。