字节流与字符流8(综合实战 文件拷贝)
2019-01-29 本文已影响0人
秋笙fine
模拟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字节流对象,就需要按照以上方法进行内容输出。
总结:
本程序属于之前的一个总结程序。以后的开发之中,以上的代码肯定会使用到