Golang中UDP支持广播与多播,广播用于局域网服务发现,需设置广播地址并启用广播选项,如192.168.1.255:8080;多播则通过组播组(224.0.0.0/8)实现高效一对多通信,接收端须加入组,如224.0.0.1:9999,适用于音视频流分发,相比TCP更轻量,适合实时场景。

在 Golang 中,UDP 协议支持广播和多播通信,适用于局域网内一对多或一对所有设备的数据分发。相比 TCP,UDP 更轻量、无连接,适合对实时性要求较高的场景。下面通过具体示例展示如何实现 UDP 广播和多播通信。
广播是指将数据包发送到本地网络中的所有主机,通常用于发现服务或设备。要实现广播,需将 UDP 地址设置为广播地址(如 192.168.1.255),并启用套接字的广播选项。
发送端代码:
func main() { addr, err := net.ResolveUDPAddr("udp", "192.168.1.255:8080") if err != nil { log.Fatal(err) }conn, err := net.DialUDP("udp", nil, addr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
// 启用广播
if err := conn.SetWriteBuffer(1024); err != nil {
log.Fatal(err)
}
for {
_, err := conn.Write([]byte("Hello from broadcaster"))
if err != nil {
log.Println("发送失败:", err)
} else {
log.Println("广播消息已发送")
}
time.Sleep(2 * time.Second)
}}
接收端代码:
立即学习“go语言免费学习笔记(深入)”;
func main() { addr, err := net.ResolveUDPAddr("udp", ":8080") if err != nil { log.Fatal(err) }conn, err := net.ListenUDP("udp", addr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
buf := make([]byte, 1024)
for {
n, clientAddr, err := conn.ReadFromUDP(buf)
if err != nil {
log.Println("接收失败:", err)
continue
}
log.Printf("来自 %s 的广播消息: %s", clientAddr, string(buf[:n]))
}}
注意:广播仅限于本地子网,且发送端需确保网络接口允许广播。
多播(Multicast)是一种更高效的通信方式,允许将数据发送到特定的组播组(IP 范围为 224.0.0.0 到 239.255.255.255)。只有加入该组的主机才能接收到消息。
发送端代码:
func main() { addr, err := net.ResolveUDPAddr("udp", "224.0.0.1:9999") if err != nil { log.Fatal(err) }conn, err := net.DialUDP("udp", nil, addr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
for {
_, err := conn.Write([]byte("Hello from multicast sender"))
if err != nil {
log.Println("发送失败:", err)
} else {
log.Println("多播消息已发送")
}
time.Sleep(3 * time.Second)
}}
接收端代码:
立即学习“go语言免费学习笔记(深入)”;
func main() { addr, err := net.ResolveUDPAddr("udp", "224.0.0.1:9999") if err != nil { log.Fatal(err) }conn, err := net.ListenMulticastUDP("udp", nil, addr)
if err != nil {
log.Fatal(err)
}
defer conn.Close()
// 设置接收缓冲区
conn.SetReadBuffer(1024)
buf := make([]byte, 1024)
for {
n, clientAddr, err := conn.ReadFromUDP(buf)
if err != nil {
log.Println("接收失败:", err)
continue
}
log.Printf("来自 %s 的多播消息: %s", clientAddr, string(buf[:n]))
}}
多播的优势在于节省带宽,多个接收者共享同一数据流。接收端必须显式加入多播组,系统内核会处理组成员管理。
基本上就这些。Golang 的 net 包封装了底层细节,使广播和多播实现变得简单直接。根据实际需求选择合适的方式,设备发现类场景可用广播,而音视频流分发更适合多播。
以上就是GolangUDP广播与多播通信实现示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号