Java NIO 通道(Channel)

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    JackChen1024阅读 7,885评论 1 143
  • 前言: 之前的文章《Java文件IO常用归纳》主要写了Java 标准IO要注意的细节和技巧,由于网上各种学习途径,...
    androidjp阅读 3,221评论 0 22
  • 转自 http://www.ibm.com/developerworks/cn/education/java/j-...
    抓兔子的猫阅读 2,475评论 0 22
  • (转载说明:本文非原创,转载自http://ifeve.com/java-nio-all/) Java NIO: ...
    柳岸阅读 876评论 0 3
  • (转载说明:本文非原创,转载自http://ifeve.com/java-nio-all/) Java NIO: ...
    数独题阅读 861评论 0 3

友情链接更多精彩内容