UNIX网络编程的5种IO模型
1、阻塞I/O模型:最常用的I/O模型就是阻塞I/O模型。我們以套接字接口為例來講解此模型,在進程空間中調用recvfrom,其系統調用直到數據包到達且被復制到應用進程的緩沖區中或者發生錯誤是才返回,在此期間一直會等待,進程在從調用recvfrom開始到它返回的整段時間內都是阻塞的,因為被稱為阻塞I/O模型。如圖1-1所示
2、非阻塞I/O模型:recvfrom從應用層到內核的時候,如果該緩沖區沒有數據的話,就直接返回一個EWOULDBLOCK錯誤,一般都對非阻塞I/O模型進行輪詢檢查這個狀態,看內核是不是有數據到來,如圖1-2所示
?3、I/O復用模型:Linux提供select/poll,進程通過將一個或者多個fd傳遞給select或者poll系統調用,阻塞在select操作上,這樣select/poll可以幫我們偵測多個fd是否處于就緒狀態。select/poll是順序掃描fd是否就緒,而且支持的fd數量有限,因為它的使用受到一些制約。Linux還提供了epoll系統調用,epoll使用基于事件驅動的方式代替順序掃描,因此性能更高。當有fd就緒的時候,立即調用回調函數,如圖1-3所示
4、信號啟動I/O模型:首先開啟套接字信號驅動I/O功能,并通過系統調用sigaction執行一個信號處理函數(此系統調用立即返回,進程繼續工作,它是非阻塞)。當數據準備就緒的時,就為該進程生成一個SIGIO信號,通過信號回調通知應用程序調用recvfrom來讀取數據,并通知主循環函數處理數據,如圖1-4所示
5、異步I/O:告知內核啟動某個操作,并讓內核在整個操作完成后(包括將數據從內核復制到用戶自己的緩沖區)通知我們。這種模型與信號驅動模型的主要區別是:信號驅動I/O由內核通知我們何時可以開始一個I/O操作;異步I/O模型由內核通知我們I/O操作何時完成,如圖1-5所示
?
?
?
總結
以上是生活随笔為你收集整理的UNIX网络编程的5种IO模型的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: php家乡介绍网页,家乡网站设计与实现.
- 下一篇: 张小龙《微信背后的产品观》