文档章节

java NIO学习

masterxsun
 masterxsun
发布于 2016/01/26 21:25
字数 614
阅读 11
收藏 0

接口与抽象类的区别与联系:接口和抽象类的区别,基于此,补充一点,接口和抽象类均不可被实例化

java IO与java NIO的区别:Java NIO和IO的区别

1、java NIO涉及两个类,Buffer和Channel, Buffer为一个抽象类,Channel为一个接口。继承Buffer的子类有除boolean类型之外的所有类型的Buffer:

  • ByteBuffer, CharBuffer, DoubleBuffer, FloatBuffer, IntBuffer, LongBuffer, ShortBuffer。

Buffer中三个重要的值,capacity表示Buffer的容量,limit表示读取或写入时的边界位置,写入状态下limit = capacity,读取状态下表示Buffer中含有元素的容量,position表示当前位置,写入状态下表示下一个未被写入的位置,读取状态下表示起始位置。用flip()方法转换读写状态。其实现类含有put和get系列方法为向Buffer中读写操作的方法。

在文件操作中,实现Channel的类主要涉及抽象类FileChannel,获得FileChannel的方法为

  • FileInputStream.getChannel(),  FileOutputStream.getChannel(),  RandomAccessFile.getChannel()

与文件打交道的是Channel相关的类,起到连接Buffer与文件的作用。read(ByteBuffer[] param)方法和write(ByteBuffer[] param) 起到向缓冲区读数据和写入通道的功能。

以下代码实现了文件复制功能

...
FileChannel inputChannel = new FileInputStream("D:\\test.txt").getChannel();
FileChannel outputChannel = new FileOutputStream("D:\\test2.txt").getChannel();
ByteBuffer buf = ByteBuffer.allocate(64);
while(inputChannel.read(buf)!=-1){//read返回读入buf的长度,可能为0. 如果读到文件尾,返回-1;
    buf.flip();
    outputChannel.write(buf);
    buf.clear();
}
...

2、Channel的实现类有一个map函数,将,FileInputStream和FileOutputStream映射到Buf中去。

public abstract MappedByteBuffer map(FileChannel.MapMode mode,
                   long position,
                   long size)
                              throws IOException

  • Parameters:

  • mode - One of the constants READ_ONLY, READ_WRITE, or PRIVATE defined in the FileChannel.MapMode class, according to         whether the file is to be mapped read-only, read/write, or         privately (copy-on-write), respectively

  • position - The position within the file at which the mapped region         is to start; must be non-negative

  • size - The size of the region to be mapped; must be non-negative and         no greater than Integer.MAX_VALUE

  • Returns:

  • The mapped byte buffer

以下是用其map方法实现的文件复制功能:

...
File file = new File("D:\\test.txt").;
FileChannel inputChannel = new FileInputStream(file).getChannel();
FileChannel outputChannel = new FileOutputStream("D:\\test2.txt").getChannel();
ByteBuffer buf = inputChannel.map(MapMode.Read_ONLY,0,file.length())
outputChannel.write(buf);
buf.clear();
...

3、java7发布了nio.2提供了Files、Paths等final Class,提供了一系列简便的文件操作方法。用nio.2的方法实现文件复制非常简单。

public static long copy(Path source,
        OutputStream out)
                 throws IOException

  • Parameters:

  • source - the  path to the file

  • out - the output stream to write to

  • Returns:

  • the number of bytes read or written

...
Files.copy(Paths.get("D:"+File.separator+"test1.txt"),new FileOutputStream("D:"+File.separator+"test2.txt"));
...









© 著作权归作者所有

共有 人打赏支持
masterxsun
粉丝 0
博文 8
码字总数 2918
作品 0
长宁
Java NIO ByteBuffer学习

深入理解Apache Mina (6)---- Java Nio ByteBuffer与Mina ByteBuffer的区别 http://chinaestone.iteye.com/blog/468138 DirectBuffer及内存泄漏 http://blog.csdn.net/zhouhl_cn/article/d......

mj4738
2012/10/15
0
0
分别使用Java IO、NIO、Netty实现的一个Echo Server示例

分别使用Java IO、Java NIO、Netty来实现一个简单的EchoServer(即原样返回客户端的输入信息)。 Java IO int port = 9000;ServerSocket ss = new ServerSocket(port);while (true) {final S...

zgw06629
2015/05/24
0
0
Java NIO AsynchronousFileChannel

原文链接 , 原文作者:Jakob Jenkov, 翻译:Neil Hao 在Java 7,AsynchronousFileChannel 被添加到了Java NIO中。使用AsynchronousFileChannel可以实现异步地读取和写入文件数据。 创建一个A...

Neil_Hao
01/20
0
0
Java NIO原理 图文分析及代码实现

Java NIO原理图文分析及代码实现 前言: 最近在分析hadoop的RPC(Remote Procedure Call Protocol ,远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术...

囚兔
2015/04/29
0
0
Java NIO系列教程(十二) Java NIO与IO

原文地址:http://tutorials.jenkov.com/java-nio/nio-vs-io.html 作者:Jakob Jenkov 当学习了Java NIO和IO的API后,一个问题马上涌入脑海: 我应该何时使用IO,何时使用NIO呢?在本文中,我...

_夏天的风_
2013/07/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

c语言之内存分配笔记

先看一个数组: short array[5] = {1,2} // 这儿定义的一个int类型的数组,数组第1和第2个元素值是1和2.其余后面默认会给值为0; 或者 short array[] = {1,2};//这儿数组第1和第2个元素,数组...

DannyCoder
46分钟前
0
0
Shell | linux安装包不用选择Y/N的方法

apt-get install -y packageOR echo "y" | sudo apt-get install package

云迹
今天
1
0
Hadoop的大数据生态圈

基于Hadoop的大数据的产品圈 大数据产品的一句话概括 Apache Hadoop: 是Apache开源组织的一个分布式计算开源框架,提供了一个分布式文件系统子项目(HDFS)和支持MapReduce分布式计算的软件架...

zimingforever
今天
4
0
八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
今天
2
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部