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)