亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

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

系統(tǒng) 2655 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 復(fù)用( select poll

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

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



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

應(yīng)用程序調(diào)用一個 IO 函數(shù),導(dǎo)致應(yīng)用程序阻塞,等待數(shù)據(jù)準(zhǔn)備好。

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

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

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

?

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



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

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

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


l ?????????
I/O 復(fù)用模型

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

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

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



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

?

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

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

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

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

這個操作和信號驅(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 操作引起請求進(jìn)程阻塞,直到 I/O 操作完成。異步 I/O 操作不引起請求進(jìn)程阻塞。

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

Java nio 和多路復(fù)用

java 1.4 nio 提供的 select ,這是一種多路復(fù)用 I/O multiplexed non-blocking I/O )模型,底層是使用 select 或者 poll I/O 復(fù)用就是,阻塞在 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)絡(luò)協(xié)議上java對于TCP/IP和UDP/IP均支持,在網(wǎng)絡(luò)IO的操作上,目前java僅支持BIO和NIO兩種方式。"

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


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 免费视频成人国产精品网站 | 久久国产精品吴梦梦 | 欧美一区永久视频免费观看 | 毛片女女女女女女女女女 | 亚洲片在线 | 国产福利资源 | 深夜免费看| freexxxx性大陆另类 | 伊人久久影视 | 午夜亚洲国产理论秋霞 | 久久精品免观看国产成人 | 中文字幕在线视频免费观看 | 国产国语一级毛片中文 | 91九色首页 | 激情五月综合网 | 视频精品一区 | 日本在线有码 | 国产国拍亚洲精品福利 | 欧美黄视频在线观看 | 久久美剧免费在线观看 | 久久99精品福利久久久 | 今天的恋爱未删减在线观看 | 欧美亚洲另类久久综合 | 久久只有精品 | 亚洲欧美在线观看一区二区 | 九九九九热精品视频 | 99热久久国产这里是精品 | 色爱区综合激月婷婷激情五月 | 香蕉久草在线 | 国内精品久久久久久麻豆 | 日日撸 | 亚洲欧美日韩精品久久 | 91日韩视频在线观看 | 日本亚洲精品一区二区三区 | 亚洲成人网在线播放 | 中文字幕三级在线不卡 | 一级片在线免费观看 | 簧片在线播放 | 国产精品欧美韩国日本久久 | 男人看片网站 | 日韩午夜在线视频 |