Java-NIO(四):通道(Channel)的原理與獲取


  • 通道(Channel):

  由java.nio.channels包定義的,Channel表示IO源與目標打開的連接,Channel類似於傳統的“流”,只不過Channel本身不能直接訪問數據,Channel只能與Buffer進行交互。通道主要用於傳輸數據,從緩沖區的一側傳到另一側的實體(如文件、套接字...),反之亦然;通道是訪問IO服務的導管,通過通道,我們可以以最小的開銷來訪問操作系統的I/O服務;順便說下,緩沖區是通道內部發送數據和接收數據的端點。

  在標准的IO當中,都是基於字節流/字符流進行操作的,而在NIO中則是是基於Channel和Buffer進行操作,其中的Channel的雖然模擬了流的概念,實則大不相同。

區別 Stream Channel
支持異步 不支持 支持
是否可雙向傳輸數據 不能,只能單向 可以,既可以從通道讀取數據,也可以向通道寫入數據
是否結合Buffer使用 必須結合Buffer使用
性能 較低 較高

早一代IO操作是由CPU負責IO接口:

新一代DMA授權處理IO接口:

通道(Channel)模式:

  • 通道的獲取方法:

java.nio.channels.Channel接口:

  |--FileChannel

  |--SocketChannel

  |--ServerSocketChannel

  |--DatagramChannel

獲取通道的方法

1)Java針對支持通道的類提供了getChannel()方法

本地IO:

|--FileInputStream/FileOutputStream

|--RandomAccessFile

網絡IO:

|--Socket

|--ServerSocket

|--DatagramSocket

|--Pip.***

2)在JDK1.7中的NIO.2針對各個通過提供了靜態方法open()

3)在JDK1.7中的NIO.2的Files工具類的newByteChannel()

4)Channles工具類中提供了靜態方法newChannel()。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM