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

相关推荐
半盏茶香6 分钟前
扬帆数据结构算法之雅舟航程,漫步C++幽谷——LeetCode刷题之移除链表元素、反转链表、找中间节点、合并有序链表、链表的回文结构
数据结构·c++·算法
加油,旭杏9 分钟前
【go语言】变量和常量
服务器·开发语言·golang
H.2016 分钟前
centos7执行yum操作时报错Could not retrieve mirrorlist http://mirrorlist.centos.org解决
linux·centos
wanhengidc29 分钟前
网站服务器中的文件被自动删除的原因
运维·服务器
DARLING Zero two♡1 小时前
【初阶数据结构】逆流的回环链桥:双链表
c语言·数据结构·c++·链表·双链表
9毫米的幻想1 小时前
【Linux系统】—— 编译器 gcc/g++ 的使用
linux·运维·服务器·c语言·c++
带多刺的玫瑰1 小时前
Leecode刷题C语言之从栈中取出K个硬币的最大面积和
数据结构·算法·图论
helloliyh1 小时前
Windows和Linux系统安装东方通
linux·运维·windows
Cando学算法1 小时前
Codeforces Round 1000 (Div. 2)(前三题)
数据结构·c++·算法
小深ai硬件分享2 小时前
Keras、TensorFlow、PyTorch框架对比及服务器配置揭秘
服务器·人工智能·深度学习