Linux学习(17)-I/O复用(1)select、poll

本节学习内容

1.I/O复用的作用

2.select接口(1.select接口的作用2.select相关接口3.select编程流程4.代码实现select)

3.poll接口

4.select与poll对比

一、I/O复用的作用

I/O复用使得程序同时监听多个文件描述符。(简单说:I/O复用相当于监视发送端谁有数据,有数据再去处理,从而做到类似于多线程编程)

二、select接口

1.select接口的作用

1)select只会监听三类事件(读、写、异常)

2)select只有LT操作模式(电平触发模式)

3)select接口流程:

第一步:监听文件描述符是否就绪

第二步:将就绪的文件描述符存放到fd_set集合中

第三步:检测fd_set中是否有文件描述符被设置

第四步:如果有,处理文件描述符中的事件(如果此过程产生新的描述符,将新描述符送至第二步)

第五步:所有事件处理完,关闭端口。

2.select相关接口

FD_ZERO( fd _ set* fdset); // 清除 fdset的所有位

FD_SET( int fd, fd _ set* fdset); // 将文件描述符添加到fdsrt中,对应位置值置1

FD_CLR( int fd, fd _ set* fdset); // 清除 fdset某一个位

int FD_ISSET( int fd, fd _ set* fdset);// 测试 fdset的位 fd 是否被设置

3.select编程流程(服务器端)

步骤:

1)创建套接字(指定端口、监听)

2)创建文件描述符(将套接字加入到文件描述符中)

3)创建fd_set集合(将文件描述符加到fd_set集合中)

4)创建select接口来监听文件描述符(如果文件描述符未就绪,阻塞)

5)文件描述符已就绪,判断文件描述符(连接套接字还是接收套接字)

6)连接套接字:接受内容并回复

接受套接字:将接受套接字将其转化为连接套接字从 2)步骤重新开始

7)关闭

4.代码实现select

服务器端:

客户端:

运行结果如下

三、poll接口

1.poll的作用

poll与select相似,也是一定时间内轮询一定数量的文件描述符,以测试其中是否就绪

不同:

(1)poll支持的事件类型更多

(2)不用像select一样有fdset集合,只用维护好poll数组(结构体)即可

2.poll支持的事件类型

3.代码实现poll

服务器端:

客户端代码与select客户端相同

结果如下

四、select与poll对比

相同点:

1.每次循环都要将所有描述符拷贝到内核空间

2.内核的实现方式都是 轮询 时间复杂度为O(n)

3.都是通过遍历所有描述符来找到就绪描述符 时间复杂度O(n)

4.都只有LE操作模式(电平操作)

不同点:

1.select只能处理三类事件(读、写、异常),poll可以处理多种时间(如上图poll事件表)

2.poll不需要创建fd_set集合,只需要定义poll结构体维护好poll数组即可

相关推荐
贾saisai7 分钟前
Xilinx系FPGA学习笔记(九)DDR3学习
笔记·学习·fpga开发
suifen_8 分钟前
RK3229_Android9.0_Box 4G模块EC200A调试
网络
北岛寒沫11 分钟前
JavaScript(JS)学习笔记 1(简单介绍 注释和输入输出语句 变量 数据类型 运算符 流程控制 数组)
javascript·笔记·学习
2401_8582861113 分钟前
52.【C语言】 字符函数和字符串函数(strcat函数)
c语言·开发语言
铁松溜达py14 分钟前
编译器/工具链环境:GCC vs LLVM/Clang,MSVCRT vs UCRT
开发语言·网络
CoolTiger、1 小时前
【Vmware16安装教程】
linux·虚拟机·vmware16
jiao000012 小时前
数据结构——队列
c语言·数据结构·算法
铁匠匠匠2 小时前
从零开始学数据结构系列之第六章《排序简介》
c语言·数据结构·经验分享·笔记·学习·开源·课程设计
C-SDN花园GGbond2 小时前
【探索数据结构与算法】插入排序:原理、实现与分析(图文详解)
c语言·开发语言·数据结构·排序算法
学习3人组2 小时前
CentOS 中配置 OpenJDK以及多版本管理
linux·运维·centos