JAVA使用字节流与高速缓冲字节流复制文件对比

时间:2022-01-24 20:58:45

好记性不如赖笔头……

/**
* @author Ckinghan
* @描述:使用字节流复制文件与使用高速缓冲流复制文件的对比示例
* WebLogin.log 文件大小:15,028,378 字节(14.3M)
*/

package com.Ckinghan.outputStream;

import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

/** * @author Ckinghan * @描述:使用字节流复制文件与使用高速缓冲流复制文件的对比示例 * WebLogin.log 文件大小:15,028,378 字节(14.3M) */
public class InputStreamCopyCompared {

    public static void main(String[] args) {
        long startTime = System.currentTimeMillis();
        //字节流复制文件,复制方式:一次读取一个字符
        stringFileCopy();
        long endTime = System.currentTimeMillis();
        System.out.println("字节流复制文件,复制方式:一次读取一个字符耗时:"+(endTime-startTime)+"毫秒复制成功");

        startTime = System.currentTimeMillis();
        //使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符
        bufferedInputStreamReader();
        endTime = System.currentTimeMillis();
        System.out.println("使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符耗时:"+(endTime-startTime)+"毫秒复制成功");

        startTime = System.currentTimeMillis();
        //用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节
        FileCopy();
        endTime = System.currentTimeMillis();
        System.out.println("字节流复制文件,复制方式:一次复制指定数量的字节耗时:"+(endTime-startTime)+"毫秒复制成功");

        startTime = System.currentTimeMillis();
        //用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节
        bufferedInputStreamCopyFile();
        endTime = System.currentTimeMillis();
        System.out.println("用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节耗时:"+(endTime-startTime)+"毫秒复制成功");
    }

    /** * @描述:字节流复制文件,复制方式:一次读取一个字符 * @创建时间: */
    public static void stringFileCopy(){
        //创建字节的输出、输出流
        InputStream inputStream = null;
        OutputStream outputStream = null;
        try {
            //实例化字节输入、输出流
            inputStream = new FileInputStream("E:/WebLogin.log");
            outputStream = new FileOutputStream("E:/new3.log");
            //创建读取的字节ACSII码
            int len = -1;
            //循环读取文件数据
            while ((len = inputStream.read()) != -1) {
                //写入文件
                outputStream.write(len);
            }
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            //如果输出、输入字节流有创建,则关闭,注意关闭顺序,先关输出流再关输入流
            try {
                if(outputStream != null)
                    outputStream.close();
                if(inputStream != null)
                    inputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

    }

    /** * @描述:字节流复制文件,复制方式:一次复制指定数量的字节 * @创建时间: */
    public static void FileCopy(){
        //创建流对象
        InputStream inputStream = null;
        OutputStream stream = null;

        try {
            //实例化流对象
            inputStream = new FileInputStream("E:/WebLogin.log");
            stream = new FileOutputStream("E:/new2.log");
            //接收读取的字节长度
            int len = -1;
            //接收读取的字节
            byte[] bs = new byte[1024];
            //循环读取字节
            while((len = inputStream.read(bs)) != -1){
                //将读取的字节写入到文件中
                stream.write(bs, 0, len);
            }
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            try {
                //关闭输出流
                if(stream != null)
                    stream.close();
                //关闭输入流
                if(inputStream != null)
                    inputStream.close();
            } catch (IOException e2) {
                e2.printStackTrace();
            }
        }

    }

    /** * @描述:用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节 * @创建时间: */
    public static void bufferedInputStreamCopyFile(){
        //创建字节流对象
        InputStream inputStream = null;
        OutputStream outputStream = null;

        try {
            //实例化高效缓冲区字节流的输入、输出对象
            inputStream = new BufferedInputStream(new FileInputStream("E:/WebLogin.log"));
            outputStream = new BufferedOutputStream(new FileOutputStream("E:/new.log"));
            //每次读取的文件字节数量
            int len = -1;
            //每次读取的文件字节数据
            byte[] bs = new byte[1024];
            //循环读取文件,直至读到文件末尾
            while ((len = inputStream.read(bs)) != -1) {
                //写入到文件
                outputStream.write(bs, 0, len);
            }
            //清空缓冲区,将写入到文件中的数据保存
            outputStream.flush();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            try {
                //关闭流
                if(outputStream != null)
                    outputStream.close();
                if(inputStream != null)
                    inputStream.close();
            } catch (IOException e2) {
                e2.printStackTrace();
            }
        }
    }

    /** * @描述:使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符 * @创建时间: */
    public static void bufferedInputStreamReader(){
        //创建字节流对象
        InputStream inputStream = null;
        OutputStream outputStream = null;

        try {
            //实例化高效缓冲区字节流的输入、输出对象
            inputStream = new BufferedInputStream(new FileInputStream("E:/WebLogin.log"));
            outputStream = new BufferedOutputStream(new FileOutputStream("E:/login.log"));

            //读取的字节ACSII码
            int val = -1;

            //循环读取文件,直至读到文件末尾
            while((val = inputStream.read()) != -1){
                //写入到文件
                outputStream.write(val);
            }
            //清空缓冲区,将写入到文件中的数据保存
            outputStream.flush();
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            try {
                //关闭流
                if(outputStream != null)
                    outputStream.close();
                if(inputStream != null)
                    inputStream.close();
            } catch (IOException e2) {
                e2.printStackTrace();
            }
        }

    }

}

执行结果:

字节流复制文件,复制方式:一次读取一个字符耗时:38814毫秒复制成功
使用高效缓冲区的字节流读取复制文件,复制方式:一次复制一个字符耗时:146毫秒复制成功
字节流复制文件,复制方式:一次复制指定数量的字节耗时:72毫秒复制成功
用高效缓冲区的字节流读取复制文件,复制方式:一次复制指定数量的字节耗时:37毫秒复制成功

可以看出,使用了高速缓冲流复制文件,所用时间比之未使用之前的相对较少,而且文件越大,差距越大。