Java NIO的Channel类似流,是用于传输数据的数据流,但有不同:
从Channel读数据到缓冲区,从缓冲区写数据到Channel。
Java NIO中最重要的通道的实现:
下面是一个使用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中读取数据。
参考