java培訓(xùn)自學(xué)開(kāi)發(fā)中的I/O模型原理解析,I/O是 input/output的縮寫(xiě)即輸入輸出端口。每個(gè)設(shè)備都會(huì)有一個(gè)專用的I/O地址用來(lái)處理自己的輸入輸出信息。常見(jiàn)的五種IO模型分別是:阻塞IO、非阻塞IO、多路復(fù)用IO、信號(hào)驅(qū)動(dòng)IO以及異步IO。接下來(lái)我們具體了解java培訓(xùn)自學(xué)開(kāi)發(fā)中的I/O模型:
1、BIO(Blocking IO)BIO是同步阻塞模型一個(gè)客戶端連接對(duì)應(yīng)一個(gè)處理線程。在BIO中accept和read方法都是阻塞操作,如果沒(méi)有連接請(qǐng)求accept方法阻塞;如果無(wú)數(shù)據(jù)可讀取read方法阻塞。
2、NIO(Non Blocking IO)
NIO是同步非阻塞模型服務(wù)端的一個(gè)線程可以處理多個(gè)請(qǐng)求,客戶端發(fā)送的連接請(qǐng)求注冊(cè)在多路復(fù)用器Selector上服務(wù)端線程通過(guò)輪詢多路復(fù)用器查看是否有IO請(qǐng)求有則進(jìn)行處理。NIO的三大核心組件分別如下:
(1)Buffer:用于存儲(chǔ)數(shù)據(jù)底層基于數(shù)組實(shí)現(xiàn),針對(duì)8種基本類型提供了對(duì)應(yīng)的緩沖區(qū)類。
(2)Channel:用于進(jìn)行數(shù)據(jù)傳輸面向緩沖區(qū)進(jìn)行操作支持雙向傳輸,數(shù)據(jù)可以從Channel讀取到Buffer中也可以從Buffer寫(xiě)到Channel中。
(3)Selector:選擇器當(dāng)向一個(gè)Selector中注冊(cè)Channel后,Selector 內(nèi)部的機(jī)制就可以自動(dòng)不斷地查詢(Select)這些注冊(cè)的Channel是否有已就緒的 I/O 事件(例如可讀,可寫(xiě),網(wǎng)絡(luò)連接完成等),這樣程序就可以很簡(jiǎn)單地使用一個(gè)線程高效地管理多個(gè)Channel也可以說(shuō)管理多個(gè)網(wǎng)絡(luò)連接,因此Selector也被稱為多路復(fù)用器。
當(dāng)某個(gè)Channel上面發(fā)生了讀或者寫(xiě)事件,這個(gè)Channel就處于就緒狀態(tài),會(huì)被Selector監(jiān)聽(tīng)到,然后通過(guò)Selection Keys可以獲取就緒Channel的集合進(jìn)行后續(xù)的I/O操作。Epoll是Linux下多路復(fù)用IO接口select/poll的增強(qiáng)版本,它能顯著提高程序在大量并發(fā)連接中只有少量活躍的情況下的系統(tǒng)CPU利用率,獲取事件的時(shí)候它無(wú)須遍歷整個(gè)被偵聽(tīng)的描述符集,只要遍歷那些被內(nèi)核IO事件異步喚醒而加入Ready隊(duì)列的描述符集合就行了。
3、AIO(NIO 2.0)
AIO是異步非阻塞模型一般用于連接數(shù)較多且連接時(shí)間較長(zhǎng)的應(yīng)用,在讀寫(xiě)事件完成后由回調(diào)服務(wù)去通知程序啟動(dòng)線程進(jìn)行處理。與NIO不同,當(dāng)進(jìn)行讀寫(xiě)操作時(shí)只需直接調(diào)用read或write方法即可。這兩種方法均為異步的對(duì)于讀操作而言,當(dāng)有流可讀取時(shí)操作系統(tǒng)會(huì)將可讀的流傳入read方法的緩沖區(qū)并通知應(yīng)用程序;對(duì)于寫(xiě)操作而言當(dāng)操作系統(tǒng)將write方法傳遞的流寫(xiě)入完畢時(shí)操作系統(tǒng)主動(dòng)通知應(yīng)用程序??梢岳斫鉃閞ead/write方法都是異步的完成后會(huì)主動(dòng)調(diào)用回調(diào)函數(shù)。
以上就是Java培訓(xùn)自學(xué)開(kāi)發(fā)中有哪些必會(huì)的I/O模型原理的詳細(xì)介紹,希望能對(duì)你有所幫助。
想了解更多相關(guān)資訊請(qǐng)關(guān)注Java培訓(xùn)頻道-查看更多,了解相關(guān)專業(yè)課程信息您可在線咨詢也可免費(fèi)申請(qǐng)?jiān)囌n。關(guān)注賦能網(wǎng)了解更多:4008-569-579
本文鏈接:
本文章“Java培訓(xùn)自學(xué)開(kāi)發(fā)中有哪些必會(huì)的IO模型”已幫助 96 人
免責(zé)聲明:本信息由用戶發(fā)布,本站不承擔(dān)本信息引起的任何交易及知識(shí)產(chǎn)權(quán)侵權(quán)的法律責(zé)任!
本文由賦能網(wǎng) 整理發(fā)布。了解更多培訓(xùn)機(jī)構(gòu)》培訓(xùn)課程》學(xué)習(xí)資訊》課程優(yōu)惠》課程開(kāi)班》學(xué)校地址等機(jī)構(gòu)信息,可以留下您的聯(lián)系方式,讓課程老師跟你詳細(xì)解答:
咨詢熱線:4008-569-579