channels java_Java NIO channels
Java NIO channels
Java 中的channel和流有如下的區別
既可以從通道中讀取數據,又可以寫數據到通道。但流的讀寫通常是單向的。
通道可以異步地讀寫。
通道中的數據總是要先讀到一個Buffer,或者總是要從一個Buffer中寫入。
正如上面所說,從通道讀取數據到緩沖區,從緩沖區寫入數據到通道。如下圖所示:
image
Java NIO: Channels read data into Buffers, and Buffers write data into Channels
Channel 的實現
下面是channel的重要的實現
FileChannel
DatagramChannel
SocketChannel
ServerSocketChannel
FileChannel是從file中讀取或者是寫入到file中去
DatagramChannel可以通過UDP協議從網絡中讀取或者是寫入
SocketChannel可以通過TCP協議從網絡中寫入或者是讀取
ServerSocketChannel可以監聽新進來的TCP連接,像Web服務器那樣。對每一個新進來的連接都會創建一個SocketChannel。
基本的 Channel 示例
下面是一個使用FileChannel讀取數據到Buffer中的示例:
RandomAccessFile aFile = new RandomAccessFile("data/nio-data.txt", "rw");
FileChannel inChannel = aFile.getChannel();
ByteBuffer buf = ByteBuffer.allocate(48);
int bytesRead = inChannel.read(buf);
while (bytesRead != -1) {
System.out.println("Read " + bytesRead);
buf.flip();
while(buf.hasRemaining()){
System.out.print((char) buf.get());
}
buf.clear();
bytesRead = inChannel.read(buf);
}
aFile.close();
注意 buf.flip() 的調用,首先讀取數據到Buffer,然后反轉Buffer,接著再從Buffer中讀取數據。下一節會深入講解Buffer的更多細節。
總結
以上是生活随笔為你收集整理的channels java_Java NIO channels的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 坦克科普:K2
- 下一篇: 戴尔g7怎么说明win已激活 如何确定D