Muduo网络库学习之Buffer读取与发送数据

Muduo网络库中的Buffer用于TCP通信的输入输出缓冲,解决数据一次性发送或接收不完整的问题。Buffer确保数据按顺序存储并处理TCP无边界字节流的挑战。TcpConnection类管理每个TCP连接,处理读写事件,并将读取的Buffer传递给用户进行业务处理。发送数据时,未发送完的部分会被缓存,等待可写事件再次发送,避免忙循环。
摘要由CSDN通过智能技术生成

Buffer 存在的意义

Buffer是Tcp网络编程中必不可少的东西。为什么必须要有要有Buffer。举个简单的例子,先说输出buffer,假如服务器要向客户端发送100KB数据,受到了某些因素的影响,一次性只能发送80KB,那剩余的20KB怎么办,总不可能把它丢掉吧。这时候Buffer的作用就出来了,它将缓存没发送完的20KB数据(把数据按时间顺序存好,有点像队列,先入先出),然后再次注册socket的可写事件,等到可写事件满足的时候再发送剩余的20KB数据。输入Buffer,TCP 是一个无边界的字节流协议,接收方必须要处理“收到的数据尚不构成一条完整的消息”和“一次收到两条消息的数据”等等情况。一个常见的场景是,发送方 send 了两条 10k 字节的消息(共 20k),接收方收到数据的情况可能是:

一次性收到 20k 数据
分两次收到,第一次 5k,第二次 15k
分两次收到,第一次 15k,第二次 5k
分两次收到,第一次 10k,第二次 10k
分三次收到,第一次 6k,第二次 8k,第三次 6k
其他任何可能
网络库在处理“socket 可读”事件的时候,必须一次性把 socket 里的数据读完(从操作系统 buffer 搬到应用层 buffer),否则会反复触发 POLLIN 事件,造成 busy-loop。
所以在TCP网络编程中,输入输出buffer是必须的。

Buffer的设计涉及到的东西太多,读者如果想去探究原理,可以去看陈硕大佬的 《linux 多

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值