Linux网络:I/O多路转接poll

目录

一、poll函数解析

二、events和revents事件取值

三、poll的优点

四、poll的缺点


一、poll函数解析

poll函数接口:

#include <poll.h>

int poll(struct pollfd *fds, nfds_t nfds, int timeout);

参数解析:

// struct pollfd 结构

struct pollfd

{

int fd; /* file descriptor */

short events; /* requested events */

short revents; /* returned events */

};

参数一:

fds 是一个 poll 函数一个监听的结构列表。

每一个结构体元素中, 包含了三部分内容:

1、文件描述符:fd

2、监听的事件集合:events

3、返回的事件集合:revents

参数二:

nfds 表示 fds 数组的长度是多少

参数三:

timeout 表示所设置的 poll 函数的超时时间, 单位是毫秒(ms)

poll函数返回值:

返回值小于 0, 表示出错;

返回值等于 0, 表示 poll 函数等待超时;

返回值大于 0, 表示 poll 由于监听的文件描述符就绪而返回。

二、events和revents事件取值

|-------------|-----------------------|
| | |
| POLLIN | 数据(包括普通/优先数据)可读 |
| POLLRDNORM | 普通数据可读 |
| POLLRDBAND | 优先级带数据可读 |
| POLLPRI | 高级优先级数据可读,如TCP带外数据 |
| POLLOUT | 数据(包括普通/优先数据)可写 |
| POLLWRNORM | 普通数据可写 |
| POLLWRBAND | 优先级带数据可写 |
| POLLERR | 错误 |
| POLLHUP | 挂起 |
| POLLNVAL | 文件描述符未打开 |
| POLLRDHUP | TCP连接被对方关闭,或者对方关闭了写操作 |

三、poll的优点

不同于 select 使用三个位图来表示三个 fdset 的方式,poll 使用一个 pollfd 的指针实现。

**1、**pollfd 结构包含了要监视的 event 和发生的 event,不再使用 select参数值的传递方式. 接口使用上比 select 更方便。

**2、**poll 并没有最大数量的限制 (但是数量过大后性能也是会下降),理论上我们传过去一个多大的数组,poll就处理多大。

四、poll的缺点

**1、**和 select 函数一样,poll 返回后,需要轮询 pollfd 来不断获取已经就绪的描述符。

**2、**每次调用 poll 都需要把大量的 pollfd 结构从用户态拷贝到内核中,如果pollfd过大会影响效率。

**3、**如果同时连接的大量客户端,在同一时刻可能只有很少客户端的处于就绪的状态, 因此随着需要监视的描述符数量增长, 其效率也会呈线性下降。

相关推荐
IT逆夜几秒前
实现Yum本地仓库自动同步的完整方案(CentOS 7)
linux·运维·windows
a***59269 分钟前
用nginx正向代理https网站
运维·nginx·https
S***267514 分钟前
linux上redis升级
linux·运维·redis
稚辉君.MCA_P8_Java28 分钟前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
赖small强31 分钟前
【Linux 网络基础】Linux 平台 DHCP 运作原理与握手过程详解
linux·网络·dhcp
ifanatic1 小时前
[每周一更]-(第161期):分析服务器中内存即将爆满过程
运维·服务器
无限进步_1 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
热爱学习的小怪兽1 小时前
docker的一些常用指令
运维·docker·容器
Swift社区1 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
芬加达2 小时前
leetcode34
java·数据结构·算法