`
songbin0201
  • 浏览: 320146 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java nio

 
阅读更多
从JDK1.4(merlin)开始,java提供了NIO的方式读写文件,处理线程调度。使用NIO主要有以下两个方面的好处

1、用fileChannel+buffer的方式,提高了文件的读写速度
     简单对比了一下90+M文件,buffer预分配大小为1024的时候,速度提升大概比传统io提升了3-4倍;而且buffer预分配空间越大,速度提升越高;因为nio按照连续的字节块读写文件,buffer越设置的越大,文件读写越快。
public void copyfileBIO() throws IOException{
	BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(in_filename)));
	FileOutputStream fos = new FileOutputStream(out_bio_filename);
	String str;
	while((str=br.readLine())!=null){
		fos.write(str.getBytes());
	}
	fos.flush();
	fos.close();
	br.close();
}
	
public void copyfileNIO() throws IOException{
	FileInputStream fis = new FileInputStream(in_filename);
	FileOutputStream fos = new FileOutputStream(out_nio_filename);
		
	FileChannel fc_in = fis.getChannel();
	FileChannel fc_out = fos.getChannel();
	ByteBuffer bb = ByteBuffer.allocate(1024);
	while(true){
		bb.clear();
		int r = fc_in.read(bb);
		if(r == -1){
			break;
		}
		bb.flip();
		fc_out.write(bb);
	}
	fc_out.close();
	fos.close();
	fc_in.close();
	fis.close();
}

2、提供了多路复用的非阻塞IO的访问方式
     多路复用的非阻塞IO,在IO较频繁的场景下,可以提升线程的使用率,相比与传统的bio,将io的读写等待从线程交还给系统,同时可以减少了上下文的切换,大大提升了系统资源的利用率。对线程池大小有限制的服务来说,可以有效的避免线程访问峰值时的无线程可用的情况。
     通俗的来说,就是只要需要线程干活的时候,才使用它,其他时间都把处理交回给系统,当系统事件结束,再将上下文切换给线程,让线程继续干活。这样可以保证线程的工作始终饱满,只用很少的线程就可以处理较高的并发(相对于bio来说)
分享到:
评论

相关推荐

    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 包读取超大数据文件

    Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据文件Java nio 超大数据文件 超大数据...

    Java NIO英文高清原版

    Java NIO英文高清原版

    java nio中文版

    java NIO是 java New IO 的简称,在 jdk1.4 里提供的新 api 。 Sun 官方标榜的特性如下: – 为所有的原始类型提供 (Buffer) 缓存支持。 – 字符集编码解码解决方案。 – Channel :一个新的原始 I/O 抽象。 – 支持...

    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.zip

    java NIO.zip

    java NIO 中文版

    讲解了 JavaIO 与 JAVA NIO区别,JAVA NIO设计理念,以及JDK中java NIO中语法的使用

    java nio 实现socket

    java nio 实现socketjava nio 实现socketjava nio 实现socketjava nio 实现socketjava nio 实现socket

    Java NIO 英文文字版

    Many serious Java programmers, especially enterprise Java programmers, consider the new I/O API--called NIO for New Input/Output--the most important feature in the 1.4 version of the Java 2 Standard ...

    Java Nio selector例程

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

    java NIO技巧及原理

    java NIO技巧及原理解析,java IO原理,NIO框架分析,性能比较

    Java NIO

    Java NIO 书籍,讲述new io特性 裴小星 译

    java nio 读文件

    java nio 读文件,java nio 读文件

    java nio proraming pdf

    java.nio (NIO stands for non-blocking I/O) is a collection of Java programming language APIs that offer features for intensive I/O operations. It was introduced with the J2SE 1.4 release of Java by ...

    JAVA NIO 学习资料

    JAVA NIO学习资料JAVA NIO学习资料

    Java NIO测试示例

    Java NIO测试示例

    java nio入门学习,两个pdf

    java nio入门学习,两个pdfjava nio入门学习,两个pdf

    Java NIO.pdf

    java nio编程 非阻塞模式的通信 电子书 带目录标签

Global site tag (gtag.js) - Google Analytics