面向字节流(TCP)vs 报文级(UDP)

1. 面向字节流(TCP)

TCP 把数据当成"一串连续的字节流"来看待,没有明确的"消息边界"。

特点:

  • 接收端不知道你什么时候"发了一条完整的消息"

  • 多条消息可能粘在一起(粘包)或拆成多段(拆包)

  • 数据是连续的流,你只能靠协议去切割

举个比喻:

就像一条长长的"传送带 ",你把数据一段段放上去,

对方只能看字节流,不知道哪一段是一个完整的箱子(消息)。容易导致粘包。

2. 报文级(UDP)

UDP 是"报文(包)"为单位的协议 ,一条 sendto() 对应一条完整的 recvfrom()

特点:

  • 发多少就收多少,一次 recvfrom() 只对应一条完整的 UDP 包

  • 不会出现粘包或拆包问题

  • 单个包大小有限制(最多 65,535 字节)

类比:

就像一个个快递包裹 ,每次都独立寄送,接收方一包一包地收,

你永远不会把两包收到一块,也不会收到半包。所以不会出现粘包问题。


总结对比表:

特性 TCP(字节流) UDP(报文)
数据组织方式 连续的字节流 一包一包,带边界
是否有粘包/拆包 ✅ 有,需手动处理 ❌ 没有,收多少就是发多少
是否可靠传输 ✅ 有保证(重传 + 有序) ❌ 不保证
是否面向连接 ✅ 需要连接(3次握手) ❌ 无连接,直接发
适合场景 文件传输、网页、聊天、数据库等 音视频、游戏、广播、小数据通信
相关推荐
变身缎带36 分钟前
Unity中的NetworkManager基于protobuf, Socket-TCP
tcp/ip·unity·游戏引擎
“αβ”41 分钟前
MySQL表的操作
linux·网络·数据库·c++·网络协议·mysql·https
十五年专注C++开发1 小时前
Asio2: 一个基于 Boost.Asio 封装的高性能网络编程库
网络·c++·boost·asio·asio2
牛奶咖啡132 小时前
解决配置虚拟网络后同网段的设备网络不通问题
网络·桥接模式·主机模式·配置虚拟网络后同网段设备不通·排查解决同网段同网关网络不通·重置windows主机网络·nas模式
车载测试工程师2 小时前
CAPL学习-ETH功能函数-通用函数
网络·学习·tcp/ip·capl·canoe
ICT技术最前线2 小时前
sdwan组网软件如何帮助企业提升网络效率?
网络·sdwan·宽带组网
老蒋新思维3 小时前
创客匠人洞察:AI 时代 IP 变现的认知重构,从流量焦虑到价值深耕的破局之道
网络·人工智能·tcp/ip·重构·知识付费·创始人ip·创客匠人
Cher ~5 小时前
【协议】ICMP
网络·网络协议
丁丁丁梦涛6 小时前
EMQX配置 ssl 和 wss
网络·网络协议·ssl·emqx·wss
大熊背6 小时前
ISP基本框架及软硬件算法实现介绍目录
网络·接口隔离原则