I/O复用函数的比较
select poll 和 epoll 三組I/O復用系統調用都能夠同時監聽多個文件描述符。它們將等到由timeout參數指定的超時時間,直到一個或者多個文件描述符上有時間發生時返回,返回值就是就緒的文件描述符的數量。返回0表示沒有事件發生。現在我們從事件集 最大支持文件描述符數和具體實現等四個方面進一步比較它們的異同,以明確在實際應用中應該選擇哪個。
這三組函數都是通過某種結構體變量來告訴內核監聽那些文件描述符上的那些事件,并使用該結構體類型的參數來獲取內核處理的結果。
select的參數類型是fd_set沒有將文件描述符和事件進行綁定,它僅僅是一個文件描述符的集合,因此select需要提供三個這種類型的參數來分別傳入和輸出可讀 可寫及異常等事件。這一方面使得select不能處理更多類型的事件,另一方面由于內核對fd_set集合的在線修改,應用程序下次調用select前不得不重置這三個fd_set集合。
poll的參數類型pollfd則多少聰明一些。他把文件描述符和事件都定義其中,任何事件都統一處理,從而使得編程接口簡潔得多。并且內核每次修改的是pollfd結構體的revent成員,而events成員保持不變,因此下次調用poll時應用程序無需重置pollfd類型的事件集參數。
由于每次select 和poll調用都返回整個用戶注冊的事件集合,所以應用程序索引就緒文件描述符的事件復雜度為N。epoll則采用與select和poll完全不同的方式來管理用戶注冊的事件。它在內核中維護一個事件表,并提供一個獨立的系統調用epoll_ctl來控制往其中添加 刪除 修改事件。這樣每次epoll_wait調用都直接從該內核事件表中取得用戶注冊的事件,而無須反復從用戶空間讀取這些事件。epoll_wait系統調用的events參數僅用戶返回就緒的事件,這使得應用程序索引就緒文件描述符的時間復雜度為1。
總結
以上是生活随笔為你收集整理的I/O复用函数的比较的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PHP -----上传文件
- 下一篇: C程序中常见的内存操作错误