Java通道(Channel)的实现及优势
- 通道(Channel):
- 由java.nio.channels包定義的,Channel表示IO源與目標打開的連接,Channel類似于傳統的“流”,只不過Channel本身不能直接訪問數據,Channel只能與Buffer進行交互。通道主要用于傳輸數據,從緩沖區的一側傳到另一側的實體(如文件、套接字...),反之亦然;通道是訪問IO服務的導管,通過通道,我們可以以最小的開銷來訪問操作系統的I/O服務;順便說下,緩沖區是通道內部發送數據和接收數據的端點。 - 在標準的IO當中,都是基于字節流/字符流進行操作的,而在NIO中則是是基于Channel和Buffer進行操作,其中的Channel的雖然模擬了流的概念,實則大不相同。 - 區別StreamChannel - 支持異步 - 不支持 - 支持 - 是否可雙向傳輸數據 - 不能,只能單向 - 可以,既可以從通道讀取數據,也可以向通道寫入數據 - 是否結合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()。 - ? 
 - 傳統的數據流: 
 CPU處理IO,性能損耗太大
 改為:
 內存和IO接口之間加了 DMA(直接存儲器),DMA向CPU申請權限,IO的操作全部由DMA管理。CPU不要干預。
 若有大量的IO請求,會造成DMA的走線過多,則也會影響性能。- 則改DMA為Channel,Channel為完全獨立的單元,不需要向CPU申請權限,專門用于IO。 
總結
以上是生活随笔為你收集整理的Java通道(Channel)的实现及优势的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 目前梦幻山东区人最多的服务器,《梦幻西游
- 下一篇: linux重置网络的命令,linux系统
