字节流与字符流8(综合实战 文件拷贝)

模拟DOS系统的文件拷贝程序,实现字节流的综合使用。
DOS系统中文件拷贝命令:copy 源文件路径 目标文件路径

方法一:将所有的文件内容一次性读取到程序之中,而后一次性输出。
要开辟一个与文件大小一样的数组,但是如果文件过大呢?程序就崩溃了。

方法二:采用边读边输出的方式。那么现在就不会占用过大的内存空间。

范例:代码的基本实现

public class TestDemo{
    
    public static void main(String[] args) throws Exception{
        long start=System.currentTimeMillis();
        if(args.length!=2){//这里设置了args[0]为源代码路径 args[1]为拷贝文件路径
            System.out.println("error");
            System.exit(1);//程序强制退出
        }
        //如果参数正确 那么进行文件的验证
        File inFile=new File(args[0]);
        if(!inFile.exists()){//源文件不存在
            System.out.println("error");
            System.exit(1);
        }

        //有源文件,现在保证输出文件目录存在
        File outFile=new File(args[1]);
        if(!outFile.getParentFile().exists()){//目标文件不存在
            outFile.getParentFile().mkdirs();
        }

        //实现文件内容的拷贝
        InputStream input=new FileInputStream(inFile);
        OutputStream output=new FileOutputStream(outFile);

        //实现文件拷贝
        int temp=0;
        while((temp=input.read())!=-1){//每次读取单个字节
            output.write(temp);//输出单个字节
        }
        input.close();
        output.close();
        long end=System.currentTimeMillis();
        System.out.println("cost"+(end-start));
    }   

}

的确实现了拷贝,但是拷贝的速度特别慢。现在的程序属于单个字节拷贝,每次读取一个字节,那么这个循环所耗费的时间就太长了。
如果要想改变以上代码的性能问题,那么就必须采用部分数据读取并保存的方式。回顾一下字节流的两个操作方法:
InputStream:public int read(byte[])
将内容读取到字节数组之中

OutputStream:public void write(byte[]b,int off,int len)
要设置的字节数组实际上就是在read方法里面使用的数组,一定是从字节数组的第0个元素开始输出,输出读取的数据长度。
范例:改进拷贝操作

package TestDemo;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.Reader;
import java.io.Writer;




public class TestDemo{
    
    public static void main(String[] args) throws Exception{
        long start=System.currentTimeMillis();
        if(args.length!=2){//这里设置了args[0]为源代码路径 args[1]为拷贝文件路径
            System.out.println("error");
            System.exit(1);//程序强制退出
        }
        //如果参数正确 那么进行文件的验证
        File inFile=new File(args[0]);
        if(!inFile.exists()){//源文件不存在
            System.out.println("error");
            System.exit(1);
        }

        //有源文件,现在保证输出文件目录存在
        File outFile=new File(args[1]);
        if(!outFile.getParentFile().exists()){//目标文件不存在
            outFile.getParentFile().mkdirs();
        }

        //实现文件内容的拷贝
        InputStream input=new FileInputStream(inFile);
        OutputStream output=new FileOutputStream(outFile);

        //实现文件拷贝
        int temp=0;//保存每次读取的个数
        byte data[]=new byte[1024];//每次读取1024字节
        //将每次读取的数据保存在字节数组中,并且返回读取的个数
        while((temp=input.read())!=-1){
            output.write(data,0,temp);//输出数组
        }
        input.close();
        output.close();
        long end=System.currentTimeMillis();
        System.out.println("cost"+(end-start));
    }   

}

在以后的代码编写过程之中一定会给你一个InputStream字节流对象,就需要按照以上方法进行内容输出。

总结:

本程序属于之前的一个总结程序。以后的开发之中,以上的代码肯定会使用到

猜你喜欢

转载自blog.csdn.net/weixin_34273481/article/details/87040378