日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

5種IO模型的圖解分析和比較

系統(tǒng) 2728 0

Unix 5 IO 模型的圖解分析和比較

(轉(zhuǎn)自 http://blog.csdn.net/blueboy2000/archive/2009/08/26/4485874.aspx

Unix 下共有五種 I/O 模型

l ????????? 阻塞 I/O

l ????????? 非阻塞 I/O

l ????????? I/O 復用( select poll

l ????????? 信號驅(qū)動 I/O SIGIO

l ????????? 異步 I/O Posix.1 aio_ 系列函數(shù))



l ?????????
阻塞 I/O 模型

應用程序調(diào)用一個 IO 函數(shù),導致應用程序阻塞,等待數(shù)據(jù)準備好。

如果數(shù)據(jù)沒有準備好,一直等待。。。。

數(shù)據(jù)準備好了,從內(nèi)核拷貝到用戶空, IO 函數(shù)返回成功指示。

在這種模式下,基本上 IO 操作都會用一個 Work Thread 來進行( Java )。

?

5種IO模型的圖解分析和比較



l ????????? 非阻塞 I/O 模型

我們把一個套接口設置為非阻塞就是告訴內(nèi)核,當所請求的 I/O 操作無法完成時,不要將進程睡眠,而是返回一個錯誤。這樣我們的 I/O 操作函數(shù)將不斷的測試數(shù)據(jù)是否已經(jīng)準備好,如果沒有準備好,繼續(xù)測試,直到數(shù)據(jù)準備好為止。在這個不斷測試的過程中,會大量的占用 CPU 的時間。

5種IO模型的圖解分析和比較


l ?????????
I/O 復用模型

I/O 復用模型會用到 select 或者 poll 函數(shù),這兩個函數(shù)也會使進程阻塞,但是和阻塞 I/O 所不同的是,這兩個函數(shù)可以同時阻塞多個 I/O 操作。而且可以同時對多個讀操作,多個寫操作的 I/O 函數(shù)進行檢測,直到有數(shù)據(jù)可讀或可寫時,才真正調(diào)用 I/O 操作函數(shù)。

5種IO模型的圖解分析和比較

目前Java 只能支持到多路復用一級,在這種模式下,在一個線程里面以阻塞的模式監(jiān)聽連接,優(yōu)點在于不用開過多的線程以阻塞的模式等待連接。



l ????????? 信號驅(qū)動 I/O 模型

?

首先我們允許套接口進行信號驅(qū)動 I/O, 并安裝一個信號處理函數(shù),進程繼續(xù)運行并不阻塞。當數(shù)據(jù)準備好時,進程會收到一個 SIGIO 信號,可以在信號處理函數(shù)中調(diào)用 I/O 操作函數(shù)處理數(shù)據(jù)。

5種IO模型的圖解分析和比較

l ?????????
異步 I/O 模型

調(diào)用 aio_read 函數(shù),告訴內(nèi)核描述字,緩沖區(qū)指針,緩沖區(qū)大小,文件偏移以及通知的方式,然后立即返回。當 內(nèi)核 將數(shù)據(jù)拷貝到緩沖區(qū)后,再通知應用程序。

這個操作和信號驅(qū)動的區(qū)別就是:異步模式等操作完畢后才通知用戶程序而信號驅(qū)動模式在數(shù)據(jù)到來時就通知用戶程序。

5種IO模型的圖解分析和比較

幾種
I/O 模型的比較

前四種模型的區(qū)別是第一階段,第二階段基本相同,都是將數(shù)據(jù)從內(nèi)核拷貝到調(diào)用者的緩沖區(qū)。而異步 I/O 的兩個階段都不同于前四個模型。

5種IO模型的圖解分析和比較


同步
I/O 和異步 I/O

a. 同步 I/O 操作引起請求進程阻塞,直到 I/O 操作完成。異步 I/O 操作不引起請求進程阻塞。

b. 我們的前四個模型都是同步 I/O ,只有最后一個異步 I/O 模型是異步 I/O

Java nio 和多路復用

java 1.4 nio 提供的 select ,這是一種多路復用 I/O multiplexed non-blocking I/O )模型,底層是使用 select 或者 poll I/O 復用就是,阻塞在 select 或者 poll 系統(tǒng)調(diào)用的某一個之上,而不是阻塞在真正的 I/O 系統(tǒng)調(diào)用之上。 JDK 5.0 update 9 JDK 6.0 linux 下支持使用 epoll ,可以提高并發(fā) idle connection 的性能( http://blogs.sun.com/alanb/entry/epoll )。

"BIO是指阻塞IO方式,即讀和寫必須為同步方式,NIO是指異步讀,同步寫的方式,AIO是指異步讀,異步寫的方式。
在網(wǎng)絡協(xié)議上java對于TCP/IP和UDP/IP均支持,在網(wǎng)絡IO的操作上,目前java僅支持BIO和NIO兩種方式。"

5種IO模型的圖解分析和比較


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 准格尔旗| 临邑县| 会东县| 沅江市| 星子县| 县级市| 申扎县| 贡嘎县| 新邵县| 峨眉山市| 修文县| 潼南县| 濮阳县| 浠水县| 宁国市| 临夏县| 壤塘县| 铁力市| 肇东市| 德化县| 永靖县| 英吉沙县| 五莲县| 周至县| 山阴县| 文成县| 堆龙德庆县| 广安市| 富蕴县| 唐海县| 西乌珠穆沁旗| 陕西省| 江门市| 新丰县| 江达县| 谷城县| 临邑县| 延边| 兴义市| 龙州县| 通化市|