`
youjianbo_han_87
  • 浏览: 18650 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Java NIO系列教程(二) Channel

 
阅读更多

Java NIO的通道类似流,但又有些不同:

  • 既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。
  • 通道可以异步地读写。
  • 通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。

正如上面所说,从通道读取数据到缓冲区,从缓冲区写入数据到通道。如下图所示:

 

Channel的实现

这些是Java NIO中最重要的通道的实现:

  • FileChannel
  • DatagramChannel
  • SocketChannel
  • ServerSocketChannel

FileChannel 从文件中读写数据。

DatagramChannel 能通过UDP读写网络中的数据。

SocketChannel 能通过TCP读写网络中的数据。

ServerSocketChannel可以监听新进来的TCP连接,像Web服务器那样。对每一个新进来的连接都会创建一个SocketChannel。

基本的 Channel 示例

下面是一个使用FileChannel读取数据到Buffer中的示例:

01 RandomAccessFile aFile = new RandomAccessFile("data/nio-data.txt", "rw");
02 FileChannel inChannel = aFile.getChannel();
03  
04 ByteBuffer buf = ByteBuffer.allocate(48);
05  
06 int bytesRead = inChannel.read(buf);
07 while (bytesRead != -1) {
08  
09 System.out.println("Read " + bytesRead);
10 buf.flip();
11  
12 while(buf.hasRemaining()){
13 System.out.print((char) buf.get());
14 }
15  
16 buf.clear();
17 bytesRead = inChannel.read(buf);
18 }
19 aFile.close();

注意 buf.flip() 的调用,首先读取数据到Buffer,然后反转Buffer,接着再从Buffer中读取数据。下一节会深入讲解Buffer的更多细节。

分享到:
评论

相关推荐

    JavaNIO chm帮助文档

    Java NIO系列教程(二) Channel Java NIO系列教程(三) Buffer Java NIO系列教程(四) Scatter/Gather Java NIO系列教程(五) 通道之间的数据传输 Java NIO系列教程(六) Selector Java NIO系列教程(七) ...

    Java NIO系列教程(一) Java NIO 概述

    ### Java NIO 系列教程(一):Java NIO 概述 #### 一、引言 Java NIO(New IO)是Java SE 1.4版本引入的一个新的I/O处理框架,它提供了比传统Java IO包更高效的数据处理方式。NIO的核心在于其三大组件:Channels...

    Java NIO系列教程

    ### Java NIO 系列教程知识点详解 #### Java NIO 概述 Java NIO (New IO) 是从 Java 1.4 开始提供的一种新的 I/O 处理方式,旨在改进传统 Java IO API 的性能并引入更高效的数据处理机制。Java NIO 主要包括三大...

    Java NIO 系列教程1

    Java NIO的核心组件包括通道(Channel)、缓冲区(Buffer)和选择器(Selector)。通道是数据传输的路径,可以从通道读取数据到缓冲区,或者从缓冲区写入通道。缓冲区是存储数据的容器,它提供了一种高效、灵活的...

    Java-NIO-系列教程

    ### Java NIO 系列教程知识点详解 #### 一、Java NIO 概述 Java NIO (New IO) 是 Java SE 1.4 版本引入的一种新的输入/输出方式,它提供了一种替代传统的 Java IO 包的方式。Java NIO 主要包括三个核心组成部分:*...

    Java NIO框架Netty教程.pdf

    ### Java NIO框架Netty教程知识点解析 #### 一、Netty框架简介 Netty是一个高性能、异步事件驱动的网络应用框架,用于快速开发可维护的高性能协议服务器与客户端。它提供了对多种协议的支持,如HTTP、WebSocket、...

    Java_NIO框架Netty教程.pdf

    Java NIO(New IO)框架是Java平台中用于处理I/O操作的一种非阻塞I/O模型,相较于...通过阅读"Java NIO框架Netty教程.pdf",你可以深入理解Netty的工作原理,并学会如何在实际项目中应用Netty,提升你的网络编程能力。

    Java Nio ibm技术文档

    本文档旨在为Java程序员提供一个全面深入理解NIO库的教程,不仅涵盖了概念性的高级知识,还包括了底层编程细节。 #### 二、NIO概述 ##### 2.1 历史背景 - **原生I/O**:Java最初提供的I/O操作是基于流的,这在处理...

    基于Java NIO的网络服务器Netty生产实例.zip

    在“基于Java NIO的网络服务器Netty生产实例.zip”压缩包中,可能包含了关于如何使用Netty构建实际生产环境中的网络服务器的相关教程或代码示例。 1. **Java NIO基础**:NIO的核心组件包括Channel(通道)、Buffer...

    java nio 详解

    - **基本类型**:NIO提供了一系列缓冲区类,如`ByteBuffer`、`CharBuffer`、`IntBuffer`等,它们分别用于存储不同类型的数据。 - **状态管理**:缓冲区有四个关键状态:容量(Capacity)、限制(Limit)、位置...

    032002_【第20章:Java新IO】_通道(Channel)_java_hearing3oc_扣弄你澳大_stoppedh

    `java.hearing3oc`可能是指一个特定的教程系列或者代码示例集合,用于教授Java NIO的相关知识,`扣弄你澳大`这部分可能是误输入或者某种特定的表述,不直接影响知识点的解释。 通道接口包括以下常见的实现类: - *...

    nio入门 IBM教材,pdf格式

    - **参考资料**:本教程提供了一系列的代码示例,每个示例都是完整的 Java 程序的一部分,可以帮助读者更深入地理解 NIO 的各个组件。 - **代码下载与运行**:建议读者下载并运行这些代码示例,以加深对 NIO 概念的...

    java网络编程视频教程

    通过这系列视频教程,你将全面掌握Java网络编程的核心技术,包括基本的网络概念、Socket编程、HTTP/HTTPS交互、URL访问、NIO和WebSocket。这将为你构建网络应用、设计分布式系统或者从事服务器端开发打下坚实的基础...

    java网络教程

    相对于传统的IO模型,NIO提供了选择器(Selector)和通道(Channel)等机制,可以实现多路复用,提高网络通信的效率,尤其适合高并发场景。 通过这个Java网络教程,学习者将能够熟练地运用Java进行网络编程,包括...

    java教程 htm格式

    11. **IO与NIO**:对比传统的IO流和非阻塞IO(New IO,即NIO),以及NIO的Channel、Buffer和Selector等核心组件。 12. **网络编程**:讲解Socket编程,如何建立TCP和UDP连接,发送和接收数据。 13. **Swing与AWT**...

    《Java程序设计实用教程(第2版)》例题

    《Java程序设计实用教程(第2版)》是一本深入浅出的Java编程教材,它旨在帮助初学者和进阶者掌握Java编程的核心概念和技术。本书通过一系列精心设计的例题,逐步引导读者理解并应用Java语言的关键特性,从而提升编程...

    Java JDK 1.4 Tutorial

    JDK 1.4还引入了一系列新的APIs和特性,如`java.nio.channels.spi.AbstractInterruptibleChannel`,`java.nio.channels.spi.AbstractSelectableChannel`,`java.nio.charset.StandardCharsets`等,这些APIs丰富了...

Global site tag (gtag.js) - Google Analytics