`

Java NIO系列教程(2):Channel

 
阅读更多

 Java NIO系列教程(2):Channel

 

英文:Jakob Jenkov

译文:airu

链接:http://ifeve.com/channels/

 

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

 

  • 既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。

  • 通道可以异步地读写。

  • 通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。

 

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

                    

 

Channel的实现

 

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

 

  • FileChannel

  • DatagramChannel

  • SocketChannel

  • ServerSocketChannel

 

FileChannel 从文件中读写数据。

 

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

 

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

 

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

 

基本的 Channel 示例

 

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

 

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,接着再从Buffer中读取数据。

  • 大小: 35.6 KB
分享到:
评论

相关推荐

    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

    2. **Java NIO与IO的区别** Java IO基于流(Stream)进行操作,数据是单向流动的,即从输入流读取数据到程序,或从程序写入数据到输出流。而NIO则是基于通道和缓冲区,数据可以在通道间双向传输。此外,Java NIO的...

    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生产实例.zip

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

    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操作是基于流的,这在处理...

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

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

    java nio 详解

    ### Java NIO 详解 #### 一、引言与背景 在Java开发中,网络通信是必不可少的一部分。传统的Java I/O(通常称为BIO或Blocking I/O)在处理大量并发连接时存在一定的性能瓶颈。为了解决这些问题,在JDK 1.4中引入了...

    javaAPI

    5. **java.nio**:非阻塞I/O,提供了Channel、Buffer和Selector等,提高了I/O性能。 6. **java.awt**和**javax.swing**:这两个包用于创建图形用户界面,其中java.awt提供基本组件,javax.swing提供了更为高级和...

    nio入门 IBM教材,pdf格式

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

    Netty4.0学习笔记系列之三:构建简单的http服务

    Netty4.0学习笔记系列之三是关于构建简单的HTTP服务的教程,这主要涉及网络编程、服务器开发以及Java NIO(非阻塞I/O)的相关知识。Netty是一个高性能、异步事件驱动的网络应用程序框架,它使得开发可伸缩且稳定的...

    java教程 htm格式

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

    java网络教程

    最后,我们还要了解Java的NIO(Non-blocking Input/Output)和NIO.2。相对于传统的IO模型,NIO提供了选择器(Selector)和通道(Channel)等机制,可以实现多路复用,提高网络通信的效率,尤其适合高并发场景。 ...

    java网络编程视频教程

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

Global site tag (gtag.js) - Google Analytics