一、UDP的特点:
UDP传输的过程类似于寄信.。
• 无连接:知道对端的IP和端口号就直接进行传输,不需要建立连接。
• 不可靠:没有确认机制,没有重传机制,如果因为网络故障该段无法发到对方,UDP协议层也不会给应用层返回任何错误信息。
• 面向数据报:不能够灵活的控制读写数据的次数和数量。
二、面向数据报:
应用层交给UDP多长的报文,UDP原样发送,既不会拆分,也不会合并,用UDP传输100个字节的数据。
• 如果发送端调用一次sendto,发送100个字节,那么接收端也必须调用对应的一次recvfrom,接收100个字节,而不能循环调用10次recvfrom,每次接收10个字节。
UDP帧格式:

udp凭什么叫用户数据报?报文和报文之间都是有边界的。
UDP采用8字节定长报头,收到报文直接从头部提取8字节就是它的报头,根据目的端口号交给上层。
在应用层里的数据都会序列化成字节流,然后把报文交给下一层,要交给下一层就得添加报头,添加udp报头,填写16位源端口,填写16位目的端口,16位UDP长度代表整个报文长度,16位UDP校验和用于校验,不成功丢弃。
源ip、源端口、目标ip、目标端口、协议号这样一个五元组来标识通信。
tail指向应用层获取的数据,每向下传一层,data指针就继续往上移,传到传输层,data指针指向协议头,所谓的封装和解包,本质是data指针在缓冲区的移动。data指针+-对应层的协议长度。
报文的理解:存在许许多多的报文,需要先描述再组织
三、UDP缓冲区:
接口从缓冲区拷贝数据
• UDP没有真正意义上的发送缓冲区,调用sendto会直接交给内核,由内核将数据传给网络层协议进行后续的传输动作。
• UDP具有接收缓冲区,但是这个接收缓冲区不能保证收到的UDP报的顺序和发送UDP报的顺序一致,如果缓冲区满了,再到达的UDP数据就会被丢弃。
• 应用层给UDP多长的报文UDP就发送多长的报文,既不会拆分也不会合并。
四、基于UDP的应用层协议:
• NFS:网络文件系统
• TFTP:简单文件传输协议
• DHCP:动态主机配置协议
• BOOTP:启动协议(用于无盘设备启动)
• DNS:域名解析协议