中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

網絡編程中常見的5種I/O模型

發布時間:2020-07-30 19:13:24 來源:網絡 閱讀:944 作者:wpfbcr 欄目:網絡安全

I/O模型


Unix下共有五種I/O模型:

1>:阻塞I/O

2>:非阻塞I/O

3>:I/O多路復用

4>:信號驅動I/O

5>:異步I/O


其中前四種是同步I/O模型,只有第五種是異步的。


同步與異步:

這里的同步和兩個實體之間通信中的同步的概念是不一樣的,這里的同步是指關于這個I/O中的一系列動作都需要自己來完成,無論你是原地等待事件的發生(阻塞)還是當某個事件已經準備好的時候你去完成后面的的動作(非阻塞)都屬于同步。

異步,它是指是調用另一個執行者去完成,當執行者發現要處理的時間后調用你,你再完成這件事情,執行的過程和你的動作是不牽扯的。


阻塞與非阻塞:

阻塞是指,等待某個事件的發生,如果它沒有發生則一直等待下去直到事件發生為止。

非阻塞,不需要死死的等待,當它有返回的時候再去處理。



1>阻塞I/O

使用的I/O函數,導致程序阻塞,等待數據,如果數據沒有準備好則一直等待。

例如我們使用的阻塞式的socket創建套接字的時候,調用accept/recvfrom/connect...等都會是阻塞式的等待連接,請求或者數據的到來

網絡編程中常見的5種I/O模型

阻塞式的函數實現起來很簡單,但它有很多的問題,首先作為一個網絡的服務器,阻塞式的等待會浪費大量的資源和時間,當服務器調用函數sendto給遠端的一個客戶端發送數據時,這時候不做其他的事情那么往后的動作都堵塞在后面,這樣顯然是不合適的,解決這種問題的方法往往是創建一個進程或者線程去解決這件事,因為進程的開銷遠遠地大于線程的開銷,所以使用多線程的方法解決是很行得通的。

阻塞式的I/O的好處就是它非常的穩定,他能保證連接保證接受和發送數據的確定性,這是大多大的互聯網公司使用多線程的原因,并且使用線程池也會大大增加線程開啟的效率。


2>非阻塞式I/O

調用socket函數并將其設置為非阻塞模式,設置方式,linux下調用fcntl()函數。


非阻塞方式下,當前執行流不再以睡眠的方式來等待請求或者數據的到來,而采用輪詢的方式,這種方式的運作流程是這樣的,每隔一個時間段便返回一次,如果有數據到來則返回,如果沒有,則返回一個錯誤碼WSAEWOULDBLOCK,我們需要不斷的用循環來等待數據的成功返回,這個過程往往會占用大量的CPU。

非阻塞的缺點,雖然他不用再使等待太僵硬,但它不可避免的一次只能等待一個事件的到來。



3>信號驅動I/O

在TCPsocket中發生以下事件均會產生SIGIO信號,因為在同一個時候產生這種信號的原因太多我們不能區分到底是哪一種情況產生的SIGIO信號,所以在TCP中信號驅動是不太適合使用的,相反在UDP中卻比較適合使用。

網絡編程中常見的5種I/O模型


信號驅動的工作方式如下圖所示

網絡編程中常見的5種I/O模型


4>I/O多路復用。


這種方式下的工作方式就比較特別了,按TCPsocket來舉例,他會當listen到一個新的鏈接的時候將它放到一個集合中,當這個集合中的套接字有讀的情況,我們便讀取,有寫的情況,我們便寫,它是非阻塞I/O和信號驅動I/O再加上可以等待多個,這三個的合體,常見的函數有select,poll,epoll等,這些函數會在后面的博客中細細講述。

它的缺點就是,無論是上面所述的哪種函數,每次發送或者接受一個數據都會進入兩次內核與用戶的轉換。

I/O多路復用的模型如下圖


網絡編程中常見的5種I/O模型



5>異步I/O

當一個異步過程調用發出后,調用者不能立刻得到結果。實際處理這個調用的部件在完成后,通過狀態、通知和回調來通知調用者的輸入輸出操作

網絡編程中常見的5種I/O模型




5種I/O模型的對比如下圖

網絡編程中常見的5種I/O模型


可以看出最好的方式是異步I/O了當然它實現起來比較負責,阻塞I/O的可靠性最好。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

三原县| 台东市| 浦北县| 盈江县| 远安县| 榆树市| 博白县| 五家渠市| 永嘉县| 丹寨县| 平山县| 石城县| 冷水江市| 四会市| 阳朔县| 高州市| 库尔勒市| 九江市| 慈利县| 江口县| 苗栗县| 延寿县| 邯郸县| 河津市| 司法| 井冈山市| 定远县| 新昌县| 庄浪县| 塔河县| 喜德县| 泾阳县| 临沂市| 清水县| 怀远县| 玉树县| 洪泽县| 成都市| 彩票| 依安县| 金寨县|