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