IO多路复用大揭秘------彻底搞懂poll函数

本文详细探讨了IO多路复用的设计思路,分析了poll函数的特点和工作过程,并通过程序实例帮助读者深入理解其应用。适合网络编程爱好者和系统开发者阅读。
摘要由CSDN通过智能技术生成

 

欢迎交流 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
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值