Java NIO 通道(Channel)

Java NIO 通道(Channels )与流类似但也有一些区别:

  • 您可以读取和写入通道,流通常是单向的(读或写)。
  • 通道可以异步读写。
  • 通道总是读取或写入缓冲区。

如上所述,你将数据从通道读入缓冲区,并将数据从缓冲区写入通道。这里有一个例子:

Java NIO 通道(Channel)_第1张图片
**Java NIO: 通道将数据读入缓冲区,缓冲区将数据写入通道**

通道(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 的文本中详细介绍。

原文链接:http://tutorials.jenkov.com/java-nio/channels.html

你可能感兴趣的:(Java NIO 通道(Channel))