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