C++网络编程实战项目--Sinetlib网络库(2)——I/O复用与事件分发

从这一节开始讲解网络库代码的实现,在触及完整的运行逻辑之前,我们先来了解底层的Reactor模式关键结构。

事件分发

让我们先理清一下事件分发的概念。在linux系统中,信奉着一切皆文件的思想,对于我们网络库使用的socket套接字,也是用文件描述符来表示。现在假设我们有一个socket,这个socket连接了一个客户机,那么现在我们想象出下面这一场景:
在这里插入图片描述

可以看到,socket相当于一个电话,客户机那边也有一个,服务器就是通过这一对socket实现和客户机的通信。

但是这和实际意义上的电话又有点区别,因为我们并不能想说话就说话,具体来说,每个tcp socket在内核中都有一个接收缓冲区和发送缓冲区,客户机有消息到来实际上是存放到接收缓冲区中,而服务器要发送消息也是放在发送缓冲区等待内核发送而已。
在这里插入图片描述

现在就可引入事件的概念了,我们要朝客户发送消息需要什么条件呢?需要发送缓冲区有足够空间;同理,要读取客户发过来的消息就需要接收缓冲区有内容。因此,我们需要关注的是发送缓冲区有足够空间,这称为可写事件,关注接收缓冲区有内容,这称为可读事件

事件分发

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值