javase-NIO

JDK1.4引入了java.nio.*包,用以提高IO操作的性能。
下面做个试验测试拷贝一个59M的文件,使用不缓冲的FileInoutStream,带缓冲的BufferedFileInputStream,nio包中的FileChannel和ByteBuffer。

代码:

public class FileCopy {
    
    public static final int  BSIZE = 1024;
    
    public static void main(String[] args) {
        
        String fileFrom = "D:" + File.separator + "操作系统" +File.separator+ "week9_文件系统" +File.separator+ "video.mp4";
        String fileTo = "D:" + File.separator + "操作系统" +File.separator+ "week9_文件系统" +File.separator+ "videoCopy.mp4";
        long startMill;
        long endMill;
        startMill = System.currentTimeMillis();
        copyWithNio(fileFrom, fileTo);
        endMill = System.currentTimeMillis();
        System.out.println("use " + (endMill - startMill) / 1000 + "s");
    }
    
    public static void copyWithNoBuffer(String from, String to) {
        try {
            FileInputStream fr = new FileInputStream(from);
            FileOutputStream fw = new FileOutputStream(to);
            int i;
            while ((i = fr.read()) != -1) {
                fw.write(i);
            }
            fr.close();
            fw.close();
            
            System.out.println("end of copy");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    
    public static void copyWithBuffer(String from, String to) {
        try {
            BufferedInputStream bis = new BufferedInputStream(new FileInputStream(from));
            BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(to));
            int i;
            while ((i = bis.read()) != -1) {
                bos.write(i);
            }
            
            bis.close();
            bos.close();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    
    public static void copyWithNio(String from, String to) {
        try {
            FileChannel in = new FileInputStream(from).getChannel();
            FileChannel out = new FileOutputStream(to).getChannel();
            ByteBuffer bb = ByteBuffer.allocate(BSIZE);
            while (in.read(bb) != -1) {
                bb.flip();
                out.write(bb);
                bb.clear();
            }
            
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
    }
}

结论:

  1. FileInoutStream:24分钟
  2. BufferedFileInputStream: 5秒
  3. FileChannel和ByteBuffer: 1秒

从结论看,Nio的性能提升是很明显的。

转载于:https://www.cnblogs.com/gatsbydhn/p/5287115.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值