NIO有三個(gè)核心組件:
通道(Channels)緩存(Buffers)選擇器(Selectors)實(shí)際上,NIO的組件和類遠(yuǎn)不止這三個(gè),但這個(gè)三個(gè)組件是核心。至于其它組件,例如Pipe和FileLock只不過是圍繞在三大核心組件旁的實(shí)用工具類。因此,本文將重點(diǎn)關(guān)注這三個(gè)組件。其它組件也會(huì)在本系列其它相應(yīng)的文章里介紹。
在NIO里,所有IO都是從通道開始的。通道和流有點(diǎn)相似,可以將數(shù)據(jù)從通道讀入緩存,也可以將數(shù)據(jù)從緩存寫入通道,圖示如下:
通道和緩存都有多種類型,下面是NIO主要的通道類型列表:
FileChannel 文件通道DatagramChannel 數(shù)據(jù)報(bào)通道SocketChannel socket通道ServerSocketChannel serversocket通道如你所見,這些通道涵蓋了網(wǎng)絡(luò)IO(包括UDP和TCP)和文件IO。除此之外還有一些有意思的接口,限于篇幅,本文不提及,但在本系列相關(guān)文章將做詳述。 NIO主要的緩存類型如下:
ByteBuffer 字節(jié)緩存CharBuffer 字符緩存DoubleBuffer 雙精度浮點(diǎn)類型緩存FloatBuffer 單精度浮點(diǎn)類型緩存IntBuffer 整型緩存LongBuffer 長(zhǎng)整型緩存ShortBuffer 短整型緩存這些緩存涵蓋了你可以通過IO發(fā)送的基本數(shù)據(jù)類型:byte, short, int, long, float, double 和 char。此外,還有 MappedByteBuffer (映射字節(jié)緩存)可用來處理內(nèi)存映射文件(memory mapped files),此文也不作詳述。
選擇器允許單線程處理多個(gè)通道,這在當(dāng)程序開了很多通道連接,但每個(gè)通道連接的通信量都不大時(shí)(比如說聊天服務(wù)器)使用起來很方便。下面是單個(gè)線程使用選擇器來管理三個(gè)通道的示意圖:
使用選擇器時(shí),首先要將通道注冊(cè)到選擇器,然后調(diào)用選擇器的select()方法,這個(gè)方法會(huì)一直阻塞,直到有一個(gè)注冊(cè)了的通道準(zhǔn)備就緒觸發(fā)事件。一旦select()方法返回,線程就可以處理這些事件,諸如連接接入、數(shù)據(jù)到達(dá)等事件。
完整教程請(qǐng)看
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注