网络原理——UDP

1、 与TCP的关键区别

特性 UDP TCP
连接方式 无连接 面向连接
可靠性 不可靠 可靠
数据顺序 不保证顺序 保证顺序
传输速度 更快 相对较慢
头部开销 8字节 20-60字节
流量控制
拥塞控制
适用场景 实时应用、广播/多播 可靠性要求高的应用

2、UDP 报文结构

报文结构大致可以分为首部和载荷(需要传输的数据部分),首部又有源端口、目的端口、长度、校验和几个部分,起大小都是 2 字节。

端口号:是一个无符号的整数,范围在 0~65535

UDP长度:这里的长度是表示的整个 UDP 的长度,所以一条 UDP 数据报的最大为 64 KB

校验和:验证 UDP 数据报在传输过程过程当中是否发生出错

3、理解 UDP 的 "不可靠"

应⽤层交给 UDP 多⻓的报⽂ , UDP 原样发送, 既不会拆分, 也不会合并;

⽤ UDP 传输100个字节的数据: • 如果发送端调⽤⼀次sendto, 发送100个字节, 那么接收端也必须调⽤对应的⼀次recvfrom, 接收100 个字节; ⽽不能循环调⽤10次recvfrom, 每次接收10个字节;

也就意味着 UDP 只管发送,不会管接没接受到。

4、UDP使⽤注意事项

我们注意到, UDP 协议⾸部中有⼀个16位的最⼤⻓度. 也就是说⼀个 UDP 能传输的数据最大长度是 64K(包含 UDP ⾸部). 然⽽64K在当今的互联⽹环境下, 是⼀个⾮常⼩的数字. 如果我们需要传输的数据超过64K, 就需要在应⽤层⼿动的分包, 多次发送, 并在接收端⼿动拼装;

5、为什么不扩容 UDP 长度

很多人有疑惑,既然两字节不够,把它改成 4 字节不就能解决,为什么不扩容呢?

其主要原因就是在设计之初的定位为 "轻量级最小可行协议" ,国际互联网工程任务组(IETF)刻意保持其精简性,将复杂功能交由应用层实现。

而且互联网已经发展那么多年了,全球大大小小的设备都在遵守最初的协议,若现在扩容 ,将会使得,原来的设备无法解析数据报,产生错误。

所以我们可以的使用 TCP 来替代~~

相关推荐
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
武子康4 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
guts°5 小时前
17-VRRP
网络·智能路由器
Jewel Q5 小时前
动态路由协议基础
网络·智能路由器
宇称不守恒4.06 小时前
2025暑期—06神经网络-常见网络2
网络·人工智能·神经网络
Dreams_l6 小时前
网络编程2(应用层协议,传输层协议)
运维·服务器·网络
YuTaoShao7 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
7ACE7 小时前
Wireshark TS | 发送数据超出接收窗口
网络协议·tcp/ip·wireshark
数据与人工智能律师7 小时前
数字迷雾中的安全锚点:解码匿名化与假名化的法律边界与商业价值
大数据·网络·人工智能·云计算·区块链