接着上文IO多路复用(一)– Select、Poll、Epoll,接下来将演示一个TCP回射程序,源代码来自于该博文I/O多路复用之Select总结,在这里将其进行了整合,突出select、poll和epoll不同方法之间的比较,但是代码的结构相同,为了突出方法之间的差别,可能有的代码改动的并不合理,实际中使用并非这么写。

程序逻辑

该程序的主要逻辑如下:

服务器:

  1. 开启服务器套接字
  2. 将服务器套接字加入要监听的集合中(select的fd_set、poll的pollfd、epoll调用epoll_ctl)
  3. 进入循环,调用IO多路复用的API函数(select/poll/epoll_create),如果有事件产生:
    3.1. 服务器套接字产生的事件,添加新的客户端到监听集合中
    3.2. 客户端套接字产生的事件,读取数据,并立马回传给客户端

客户端:

  1. 开启客户端套接字
  2. 将客户端套接字和标准输入文件描述符加入要监听的集合中(select的fd_set、poll的pollfd、epoll调用epoll_ctl)
  3. 进入循环,调用IO多路复用的API函数(select/poll/epoll_create),如果有事件产生:
    3.1. 客户端套接字产生的事件,则读取数据,将其输出到控制台
    3.2. 标准输入文件描述符产生的事件,则读取数据,将其通过客户端套接字传给服务器

multiplexing.h

具体代码如下,首先是头文件

multiplexing.cpp

然后是函数的实现,从各个函数的实现可以看到select、poll、epoll在使用过程中的区别,具体看代码注释

服务器代码

客户端代码

运行结果

服务端:

客户端:

完整代码可以访问笔者github:https://github.com/yearsj/Cli…



如果想赏钱,可以用微信扫描下面的二维码,一来能刺激我写博客的欲望,二来好维护云主机的费用; 另外再次标注博客原地址 itnotebooks.com 感谢!

Terraform操作阿里云ECS,批量创建ECS云主机

利用Terraform实现运维平台的IaaS层,由于公司用的全是阿里云,所以以阿里云为例,不过既然是Terraform,其实无需太在意这个,基类封装好,什么云可以,甚至...

阅读全文

error: command ‘gcc’ failed with exit status 1 -Python3.6.9 MacOs Catalina

Shell error: command 'gcc' failed with exit status 1 -Python3.6.9 MacOs Catalina 1 ...

阅读全文

消息中间件对比及选型

消息中间件: 协助程序之间异步通信 一、消息中间件的作用: 削峰填谷 异构集成 解耦 异步隔离 二、市场上在用的消息中件特点: RocketMQ:(近几年用...

阅读全文

欢迎留言