java nio

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

[b][size=medium]1、用fileChannel+buffer的方式,提高了文件的读写速度[/size][/b]
简单对比了一下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();
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值