Java IO(描述內(nèi)存讀寫硬盤)
IO孤页,常協(xié)作I/O管搪,是Input/Output的簡稱慎皱,即輸入/輸出。通常指數(shù)據(jù)在內(nèi)部存儲器(內(nèi)存)和外部存儲器(硬盤咱旱、優(yōu)盤等)或其他周邊設(shè)備之間的輸入和輸出确丢。
輸入/輸出是信息處理系統(tǒng)(例如計算機)與外部世界(可能是人類或另一信息處理系統(tǒng))之間的通信。
輸入是系統(tǒng)接收的信號或數(shù)據(jù)吐限,輸出則是從其發(fā)送的信號或數(shù)據(jù)鲜侥。
在Java中,提供了一些列API毯盈,可以供開發(fā)者來讀寫外部數(shù)據(jù)或文件剃毒。我們稱這些API為Java IO。
IO是Java中比較重要搂赋,且比較難的知識點赘阀,主要是因為隨著Java的發(fā)展,目前有三種IO共存脑奠。分別是BIO基公、NIO和AIO。
第一種 實現(xiàn)模式Java BIO( 同步阻塞I/O模式)
BIO 全稱Block-IO 是一種同步且阻塞的通信模式宋欺。是一個比較傳統(tǒng)的通信方式轰豆,模式簡單胰伍,使用方便。但并發(fā)處理能力低酸休,通信耗時骂租,依賴網(wǎng)速。
第二種 實現(xiàn)模式Java NIO(
同步非阻塞模式
)
Java NIO斑司,全稱 Non-Block IO 渗饮,是Java SE 1.4版以后,針對網(wǎng)絡(luò)傳輸效能優(yōu)化的新功能宿刮。是一種非阻塞同步的通信模式互站。
NIO 與原來的 I/O 有同樣的作用和目的, 他們之間最重要的區(qū)別是數(shù)據(jù)打包和傳輸?shù)姆绞健T瓉淼?I/O 以流的方式處理數(shù)據(jù)僵缺,而 NIO 以塊的方式處理數(shù)據(jù)胡桃。
面向流的 I/O 系統(tǒng)一次一個字節(jié)地處理數(shù)據(jù)。一個輸入流產(chǎn)生一個字節(jié)的數(shù)據(jù)磕潮,一個輸出流消費一個字節(jié)的數(shù)據(jù)翠胰。
面向塊的 I/O 系統(tǒng)以塊的形式處理數(shù)據(jù)。每一個操作都在一步中產(chǎn)生或者消費一個數(shù)據(jù)塊揉抵。按塊處理數(shù)據(jù)比按(流式的)字節(jié)處理數(shù)據(jù)要快得多亡容。但是面向塊的 I/O 缺少一些面向流的 I/O 所具有的優(yōu)雅性和簡單性冤今。
第三種 實現(xiàn)方式 Java AIO( 異步非阻塞I/O模型 )
Java AIO,全程 Asynchronous IO茂缚,是異步非阻塞的IO戏罢。是一種非阻塞異步的通信模式。
在NIO的基礎(chǔ)上引入了新的異步通道的概念脚囊,并提供了異步文件通道和異步套接字通道的實現(xiàn)龟糕。
三種IO的區(qū)別
首先,我們站在宏觀的角度悔耘,重新畫一下重點:
BIO (Blocking I/O):同步阻塞I/O模式讲岁。
NIO (New I/O):同步非阻塞模式。
AIO (Asynchronous I/O):異步非阻塞I/O模型衬以。
同步阻塞模式:這種模式下缓艳,我們的工作模式是先來到廚房,開始燒水看峻,并坐在水壺面前一直等著水燒開阶淘。
同步非阻塞模式:這種模式下,我們的工作模式是先來到廚房互妓,開始燒水溪窒,但是我們不一直坐在水壺前面等坤塞,而是回到客廳看電視,然后每隔幾分鐘到廚房看一下水有沒有燒開澈蚌。
異步非阻塞I/O模型:這種模式下摹芙,我們的工作模式是先來到廚房,開始燒水宛瞄,我們不一一直坐在水壺前面等瘫辩,也不隔一段時間去看一下,而是在客廳看電視坛悉,水壺上面有個開關(guān)伐厌,水燒開之后他會通知我。
阻塞VS非阻塞:人是否坐在水壺前面一直等裸影。
同步VS異步:水壺是不是在水燒開之后主動通知人挣轨。
適用場景
BIO方式適用于連接數(shù)目比較小且固定的架構(gòu),這種方式對服務(wù)器資源要求比較高轩猩,并發(fā)局限于應(yīng)用中卷扮,JDK1.4以前的唯一選擇,但程序直觀簡單易理解均践。
NIO方式適用于連接數(shù)目多且連接比較短(輕操作)的架構(gòu)晤锹,比如聊天服務(wù)器,并發(fā)局限于應(yīng)用中彤委,編程比較復(fù)雜鞭铆,JDK1.4開始支持。
AIO方式適用于連接數(shù)目多且連接比較長(重操作)的架構(gòu)焦影,比如相冊服務(wù)器车遂,充分調(diào)用OS參與并發(fā)操作,編程比較復(fù)雜斯辰,JDK7開始支持舶担。
使用方式
看起來還是BIO實現(xiàn)最簡單,這也是大家用的最多的方式的原因吧.