當(dāng)前位置:
首頁 >
多路 IO 转接 :poll 函数
發(fā)布時間:2024/9/30
41
豆豆
生活随笔
收集整理的這篇文章主要介紹了
多路 IO 转接 :poll 函数
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
(1)頭文件
#include <poll.h>(2)函數(shù)原型
int poll (struct pollfd *fds, nfds_t nfds, int timeout);(3)參數(shù)
參 1:struct pollfd 類型結(jié)構(gòu)體數(shù)組的首地址 。是傳入傳出參數(shù)
參 2:數(shù)組實際有效大小 (比如數(shù)組初始化定義 100,但只使用了 5 個,nfds = 5)。
參 3:int 型 : -1代表永久阻塞,直到監(jiān)控事件發(fā)生;0代表立即返回,不阻塞進程;> 0表示等待指定的毫秒數(shù)。
(4)返回值
成功返回所監(jiān)聽的監(jiān)聽集合中滿足條件的文件描述符總數(shù)量;失敗返回-1,設(shè)置errno,若timeout=0,errno=EAGAIN則代表正常。
(5)poll 相較于 select 的優(yōu)勢
poll 突破了 1024 的限制;select 的監(jiān)聽和返回的集合是不分離的,是通過傳入傳出的方式實現(xiàn);而 poll 通過“參數(shù) 1”的結(jié)構(gòu)體實現(xiàn)請求和返回分離。
(6)poll 相較于 select 的劣勢
1不能跨平臺,只能在 linux 下使用,導(dǎo)致 poll 地位比較尷尬。
總結(jié)
以上是生活随笔為你收集整理的多路 IO 转接 :poll 函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: select 版 高并发服务器
- 下一篇: 多路 IO 转接 :epoll 函数