【Muduo源码分析】 解读muduo如何发送数据 TcpConnection Buffer

本文详细分析了Muduo网络库中TcpConnection的发送数据流程,包括使用水平触发的epoll,send函数的工作机制,以及如何在socket可写时通过handleWrite()继续发送数据。Muduo通过writeCompleteCallback_和HighWaterMarkCallback_解决数据发送过快的问题,确保网络程序的稳定运行。

本文旨在讲述muduo网络库数据的发送流程。

首先明确一点,Muduo中的epoll使用了水平触发方式,而不是边缘触发。

TcpConnection首先需要增加应用层的缓冲区

Buffer outputBuffer_; 

我们看到在TcpConnection类内,提供了两个数据发送函数,分别是TcpConnection::send,TcpConnection::sendInLoop。前者也是调用后者,保证数据的发送在IO线程内的EventLoop执行。(本博客系列都是基于Muduo的示例教程代码分析,个人认为这样更能理解整个网络库的整体流程)

void TcpConnection::send(const std::string& message)
{
  if (state_ == kConnected) {
    if (loop_->isInLoopThread()) {
      sendInLoop(message);
    } else {
      loop_->runInLoop(
          boost::bind(&TcpConnection::sendInLoop, this, message));
    }
  }
}

void TcpConnection::sendInLoop(const std::string& message)
{
  loop_->assertInLoopThread();
  ssize_t nwrote = 0;
  // if no thing in output queue, try writing directly
  //如果channel没有在写,并且buffer没有数据
  if (!channel_->isWriting() && outputBuffer_.readableBytes() == 0) {
    //直接先尽力写
    nwrote = ::write(channel_->
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值