欢迎交流 QQ 2431173627 微信 ccc17862701790
设计思路
对于poll函数工作过程的理解
poll函数工作原理与select函数类似,也是监管一系列的文件描述符,
看这些文件描述符是否可读/可写/异常,再去调用io函数读写
不过poll函数没有监管文件描述符个数的限制 ,
与 select() 在本质上没有多大差别,管理多个描述符也是进行轮询,根据描述符的状态进行处理。
特点分析
poll函数的优缺点
1、优点
(1)poll() 不要求开发者计算最大文件描述符加一的大小。
(2)poll() 在应付大数目的文件描述符的时候速度更快,相比于select。
(3)它没有最大连接数的限制,原因是它是基于链表来存储的。
(4)在调用函数时,只需要对参数进行一次设置就好了
2、缺点
(1)大量的fd的数组被整体复制于用户态和内核地址空间之间,而不管这样的复制是不是有意义。
(2)与select一样,poll返回后,需要轮询pollfd来获取就绪的描述符,这样会使性能下降
(3)同时连接的大量客户端在一时刻可能只有很少的就绪状态,因此随着监视的描述符数量的增长,其效率也会线性下降
工作过程
第一步
服务器用socket创建连接套接字 调用listen函数监听该套接字
(因为一开始只有一个连接套接字 交给poll监听 后面每个客户端调用connect 到这个连接套接字的时候 )
(在服务器端通过accept会创建针对这个客户端的读写套接字 然后把这个读写套接字加入到poll的监听列表)
(也就是说poll一开始只监听我们上面创建的这个连接套接字,到后面有客户端连接的时候会监听一个连接套接字和多个读写套接字)
第二步
poll函数的使用与select函数类似
poll函数问你:我要监管哪些套接字? 就是把你要监听的套接字加入它的监听列表
这一步实际上也是对poll函数的参数初始化的一个过程,poll函数长这样
#include <poll.h>
int poll(struct pollfd *fds, nfds_t nfds, int timeout);
(1)fds:指向一个结构体数组的第0个元素的指针,每个数组元素都是一个struct pollfd结构,
用于指定测试某个给定的fd的条件
&#x