Java NIO 通道(Channels )与流类似但也有一些区别:
- 您可以读取和写入通道,流通常是单向的(读或写)。
- 通道可以异步读写。
- 通道总是读取或写入缓冲区。
如上所述,你将数据从通道读入缓冲区,并将数据从缓冲区写入通道。这里有一个例子:
通道(Channel)的实现
这里是 Java NIO 中最重要的通道实现:
- FileChannel
- DatagramChannel
- SocketChannel
- ServerSocketChannel
FileChannel 从文件中读取数据并写到文件中去。
DatagramChannel 可以通过 UDP 在网络上读写数据。
SocketChannel 可以通过 TCP 在网络上读写数据。
ServerSocketChannel 允许你监听传入的TCP连接,就像Web服务器那样。对于每个传入连接,创建 SocketChannel。
基本的管道(Channel )示例
这里是一个使用 FileChannel 读取一些数据到缓冲区的基本示例:
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 的文本中详细介绍。