一些TCP和UDP使用问题汇总

本文探讨了TCP和UDP在网络传输中的特点,包括UDP数据包的独立性与TCP的流传输特性。针对TCP粘包现象提供了解决方案,并介绍了TLV包格式的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下面是在实际后台开发中遇到的一些关于TCP和UDP的问题,这里慢慢积累起来:


UDP连续发送2次数据包,第一次发100字节,第二次发200字节,服务端recvfrom(1000)时收到100、200还是300字节?

*:正常情况下为100字节

*:网络乱序:可能由于网络原因导致数据包乱序到达,则会收到200字节。故可在自定义UDP协议头加一个序列号标识

*:UDP是数据报文协议,每个数据包是独立的,客户端sendto多少个UDP包,服务端就得recvfrom多少次,数据包不会合并


TCP连续send2个数据包,第一次发100字节,第二次发200字节,服务端recv(1000)时收到100、200还是300字节?

*:TCP粘包:如果recv时两个数据包都已经到达,则为300字节

*:如果recv时只有100字节的数据包到达,那当然也只有100字节了

*:TCP是流传输协议,tcp/ip协议栈会自动合并TCP包,保证包的完整性。但这样本来不相关的包也会粘包,这需要用户进程自己来处理


如何处理TCP粘包现象?

* 一种常见的方法就是使用TLV包格式:即Type类型, Length长度,Value值,其中Type和Length长度固定。如当Type为1字节,Length为4字节,则先recv(5)接收5个字节,判断包类型并获取包长度len,然后recv(len)接收包体并按类型解析

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值