`

Java nio(一)

阅读更多
jdk1.4提供了java.nio包,为从根本上改善I/O的性能提供了可能,但是nio要比以前的I/O要复杂,提供了更底层的操作和更细的api。学起来并不是那么快就上手,有专门一本书
介绍nio的。我希望通过总结更好的梳理整个nio框架各个类之间的关系,从而能够灵活的使用nio包。
nio通常需要涉及到三个对象:
1、数据源:从文件中获得的FileInputStream/FileOutputStream、从socket中获得的输入输出流等
2、缓冲区对象(buffer):nio定义了一系列buffer对象,最基本的是ByteBuffer,其他还有各种基本数据类型除了boolean类型外,所对应的buffer类型。使用这些buffer一般的过程是:从数据源中读到ByteBuffer中,然后使用ByteBuffer.asXxxBuffer()转换成特定的基本类型,然后对这个基本类型的buffer进行操作;把基本类型转换成ByteBuffer类型,然后写入数据源中。
3、通道对象(channel):他提供了对数据源的一个连接,可以从文件中获得FileChannel,从Socket中获得SocketChannel,它是一个中介。提供了数据源与缓冲区之间的读写操作。
我们可以同过一句话来解释他们三者之间的关系:
channel对象提供了数据源与缓冲区之间的读写操作,是数据源与缓冲区的一个桥梁,通过这个桥梁,数据在两者之间流动。
首先我们看看这个中介Channel类的整个结构:
Channel < Closable
WritableByteChannel < Channel
InterruptibleChannel < Channel
ReadableByteChannel < Channel
GetherByteChannel < WritableByteChannel 
ByteChannel < WritableByteChannel,ReadableByteChannel 
ScatteringByteChannel < ReadableByteChannel 


Channel接口声明了两个方法:
close(),用来关闭通道
isOpen(),用于测试通道是否打开
其他的通道:
ByteChannel只是简单的合并了WritableByteChannel和ReadableChannel的,ScatteringByteChannel接口扩展了ReadableChannel接口,添加了一个读取并将数据
分布在不同缓冲区的方法,而GatheringByteChannel接口在WritableByteChannel的基础上添加了将多个独立的缓冲区写入驱动器中的方法。
Closeable:
void close()//关闭源或目的地,并释放资源
Channel:
void close()//关闭通道
void boolean isOpen()//判断通道是否打开
ReadableByteChannel:
int read(ByteBuffer input)
//将字节从通道读入input缓冲区中,返回读取的字节数,到达流结尾时,返回-1
WritableByteChannel:
int write(ByteBuffer output)
//将字节从实参output缓冲区写入通道,返回写的字节数
ByteChannel 仅仅继承了ReadableByteChannel和WritableByteChannel的方法
ScatteringByteChannel:
int read(ByteBuffer[] inputs)
//将字节从通道读入inputs缓冲区数组中,返回读取的字节,到达流末尾是,返回-1
int read(ByteBuffer[] inputs,int offset,int length)
//将字节从通道读inputs[offset]---inputs[offeset+length-1]缓冲区中
GatherByteChannel:
int write(ByteBuffer[] outputs);
//把outputs缓存区数组写入通道中
int write(ByteBuffer[] outputs,int offset,int length);
把从outputs[offset]-->outputs[offset+length-1]缓冲区写入通道中

例子:(我们忽略了各种Exception)
File file = new File("C:\\test.txt");
FileOutputStream fos = new FileOutputStream(file);
FileChannel outputChannel = fos.getChannel();
String str = "Hello,just a test";
ByteBuffer bb = ByteBuffer.wrap(str.getBytes());
outputChannel.write(bb);

先总结到这,下次总结各种Buffer及其操作。
10
1
分享到:
评论
2 楼 fuliang 2009-10-17  
david.org 写道
你好,fuliang,您可以解释一下,上述代码中
# File file = new File("C:\\test.txt");  
# FileOutputStream fos = new FileOutputStream(file);  
# FileChannel outputChannel = fos.getChannel();  
# String str = "Hello,just a test";  
# ByteBuffer bb = ByteBuffer.wrap(str.getBytes());  
# outputChannel.write(bb); 

与不使用FileChannel的具体区别么?

-dongtalk@gmail.com

没有区别,只是不同的API而已,你可以直接使用stream,但FileChannel
提供了更多的控制和功能,支持并发和内存映射,上述代码只是演示了怎么
获得channel,然后写数据,无法体现其他功能。
1 楼 david.org 2009-10-17  
你好,fuliang,您可以解释一下,上述代码中
# File file = new File("C:\\test.txt");  
# FileOutputStream fos = new FileOutputStream(file);  
# FileChannel outputChannel = fos.getChannel();  
# String str = "Hello,just a test";  
# ByteBuffer bb = ByteBuffer.wrap(str.getBytes());  
# outputChannel.write(bb); 

与不使用FileChannel的具体区别么?

-dongtalk@gmail.com

相关推荐

    java NIO和java并发编程的书籍

    java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java NIO和java并发编程的书籍java...

    JavaNIO chm帮助文档

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

    java NIO.zip

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统的I/O模型的新技术。自Java 1.4版本引入NIO后,它为Java开发者提供了更高效的数据传输方式,尤其是在处理大量并发...

    Java NIO英文高清原版

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java平台中用于替代标准I/O(BIO)模型的一种新机制。NIO在Java 1.4版本引入,提供了更高效的数据处理和通道通信方式,特别适用于高并发、大数据...

    一个java NIO的例子

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统I/O模型的新技术。在传统的Java IO模型中,读写操作是阻塞的,即当调用read或write方法时,线程会等待数据准备好或...

    java NIO 视频教程

    Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。 Java NIO: Channels and Buffers(通道和缓冲区) 标准的IO基于字节流和字符流进行操作的,...

    Java NIO 中文 Java NIO 中文 Java NIO 中文文档

    Java NIO 深入探讨了 1.4 版的 I/O 新特性,并告诉您如何使用这些特性来极大地提升您所写的 Java 代码的执行效率。这本小册子就程序员所面临的有代表性的 I/O 问题作了详尽阐述,并讲解了 如何才能充分利用新的 I/O ...

    java nio 包读取超大数据文件

    #### 一、Java NIO简介 Java NIO(New IO)是Java平台上的新输入/输出流API,它提供了与传统IO(即Java IO)不同的数据处理方式。NIO在Java 1.4版本引入,并在后续版本中得到了进一步增强和完善。相较于传统的Java ...

    java NIO技巧及原理

    Java NIO(New Input/Output)是Java标准库提供的一种I/O模型,它与传统的 Blocking I/O(IO)相比,提供了更加高效的数据传输方式。在Java NIO中,"新"主要体现在非阻塞和多路复用这两个特性上,这使得NIO更适合于...

    java NIO实例

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种新的I/O模型,它为Java应用程序提供了更高效的数据传输方式。传统的Java I/O模型(BIO)在处理大量并发连接时效率较...

    Java Nio selector例程

    java侧起server(NioUdpServer1.java),基于Java Nio的selector 阻塞等候,一个android app(NioUdpClient1文件夹)和一个java程序(UI.java)作为两个client分别向该server发数据,server收到后分别打印收到的消息...

    Java NIO Socket基本

    Java NIO(New Input/Output)是Java标准库中提供的一种I/O模型,与传统的 Blocking I/O(同步阻塞I/O)相对。NIO在Java 1.4版本引入,其设计目标是提供一种更高效、更灵活的I/O操作方式,特别适合处理大量并发连接...

    JAVA nio的一个简单的例子

    Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种I/O模型,旨在提供一种更高效、更具弹性的I/O处理方式。相比于传统的BIO( Blocking I/O)模型,NIO在处理高并发和大...

    java nio 读文件

    Java NIO(New IO)是Java 1.4版本引入的一个新模块,它提供了一种不同于标准Java IO API的处理I/O操作的方式。NIO的主要特点是面向缓冲区,非阻塞I/O,以及选择器,这些特性使得NIO在处理大量并发连接时表现出更高...

Global site tag (gtag.js) - Google Analytics