美文网首页
Java NIO 通道(Channel)

Java NIO 通道(Channel)

作者: 翼徳 | 来源:发表于2017-01-05 09:35 被阅读15次

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

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

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

    **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)

          本文链接:https://www.haomeiwen.com/subject/gocavttx.html