更新時間:2021-07-02 來源:黑馬程序員 瀏覽量:
NIO是為替代傳統(tǒng)標準的I/O而出現(xiàn)的。與標準的IO相比,NIO提供了一種與I/O不同的工作方式。NIO采用內(nèi)存映射文件的方式來處理輸入/輸出,它將文件或文件的一段區(qū)域映射到內(nèi)存中,這樣就可以像訪問內(nèi)存一樣來訪問文件了。
在標準IO中,使用的是字節(jié)流和字符流,而在NIO中,使用的是通道(Channel)和緩沖區(qū)(Buffer)。數(shù)據(jù)總是從通道讀入緩沖區(qū),或從緩沖區(qū)寫入通道。
在Java API中,與NIO相關(guān)的包介紹如下:
● java.nio:主要包含各種與Buffer相關(guān)的類。
● java.nio.channels:主要包含與Channel和Selector(多線程相關(guān)選擇器)相關(guān)的類。
● java.nio.channels.spi:主要包含與Channel相關(guān)的服務(wù)提供者編程接口
● java.nio.charset:主要包含與字符集相關(guān)的類。
● java.nio.charset.spi:主要包含與字符集相關(guān)的服務(wù)提供者編程接口。
NIO主要有三大核心部分:Buffer、Channel和Selector。其中Buffer可以被看成是一個容器,其本質(zhì)是一個數(shù)組緩沖區(qū),讀入或?qū)懗龅紺hannel中的所有對象都會先放在Buffer中;Channel是對傳統(tǒng)的輸入/輸出的模擬,在NIO中,所有的數(shù)據(jù)都需要通過通道流的形式傳輸;Selector(選擇器)用于監(jiān)聽多個通道的事件(例如:連接打開、數(shù)據(jù)到達等),主要用于多線程處理。