从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...
Java NIO系列教程(一) Java NIO 概述 Java NIO系列教程(二) Channel Java NIO系列教程(三) Buffer Java NIO系列教程(四) Scatter/Gather Java NIO系列教程(五) 通道之间的数据传输 Java NIO系列教程(六)...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java平台中用于替代标准I/O(BIO)模型的一种新机制。NIO在Java 1.4版本引入,提供了更高效的数据处理和通道通信方式,特别适用于高并发、大数据...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统的I/O模型的新技术。自Java 1.4版本引入NIO后,它为Java开发者提供了更高效的数据传输方式,尤其是在处理大量并发...
### Java NIO 处理超大数据文件的知识点详解 #### 一、Java NIO简介 Java NIO(New IO)是Java平台上的新输入/输出流API,它提供了与传统IO(即Java IO)不同的数据处理方式。NIO在Java 1.4版本引入,并在后续版本...
Java NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。 Java NIO: Channels and Buffers(通道和缓冲区) 标准的IO基于字节流和字符流进行操作的,...
Java NIO 深入探讨了 1.4 版的 I/O 新特性,并告诉您如何使用这些特性来极大地提升您所写的 Java 代码的执行效率。这本小册子就程序员所面临的有代表性的 I/O 问题作了详尽阐述,并讲解了 如何才能充分利用新的 I/O ...
Java NIO(New Input/Output)是Java标准库提供的一种I/O模型,它与传统的 Blocking I/O(IO)相比,提供了更加高效的数据传输方式。在Java NIO中,"新"主要体现在非阻塞和多路复用这两个特性上,这使得NIO更适合于...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统I/O模型的新技术。在传统的Java IO模型中,读写操作是阻塞的,即当调用read或write方法时,线程会等待数据准备好或...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种新的I/O模型,它为Java应用程序提供了更高效的数据传输方式。传统的Java I/O模型(BIO)在处理大量并发连接时效率较...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java标准库提供的一种替代传统I/O模型的新技术。在Java 1.4版本中引入,NIO提供了一种全新的I/O编程方式,使得Java开发者能够更高效地处理I/O操作...
### Java NIO 实现Socket通信详解 #### 一、NIO与传统IO的区别及优势 在探讨如何使用Java NIO实现Socket通信之前,我们需要先理解NIO(Non-blocking I/O,非阻塞I/O)与传统阻塞I/O之间的区别。 **传统阻塞I/O...
Java NIO,全称为Non-Blocking Input/Output(非阻塞输入/输出),是Java从1.4版本开始引入的一种新的I/O模型,它为Java应用程序提供了更高效、灵活的I/O操作方式。NIO与传统的 Blocking I/O(阻塞I/O)模式相比,...