Java NIO的通道類似流,但又有些不同:
#既可以從通道中讀取數據,又可以寫入資料到通道。但流的讀寫通常是單向的。
通道可以非同步地讀寫。
通道中的資料總是要先讀到一個Buffer,或是總是要從一個Buffer中寫入。
如上所說,從通道讀取資料到緩衝區,從緩衝區寫入資料到通道。如下圖所示:
這些是Java NIO中最重要的通道的實作:
FileChannel
DatagramChannel
#SocketChannel
ServerSocketChannel
FileChannel 從檔案中讀取和寫入資料。 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的更多細節。
以上是Java NIO系列教學2:Java NIO的通道類似流的詳細內容。更多資訊請關注PHP中文網其他相關文章!