下面的代码可以实现以字节为单位复制文件的功能,适合复制非文本类型的文件,为了更清楚的观测运行速率,我加入了程序计时器,代码如下:

 import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; public class Yuan {
/**
* @param args
*/
public static void main(String[] args) {
long startMili=System.currentTimeMillis();
try {
FileInputStream fis = new FileInputStream ("a.mp3");
FileOutputStream fos = new FileOutputStream ("temp.mp3");
int read = fis.read();
15 while ( read != -1 ) {
16 fos.write(read);
17 read = fis.read();
18 }
fis.close();
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
long endMili=System.currentTimeMillis();
System.out.println("总耗时为:"+(endMili-startMili)+"毫秒");
}
}

运行效果:

Java(四)-LMLPHP

但是,这段代码在复制如mp3等大文件时,运行效率很低,课后我对以上代码进行了改进:

 import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; public class Copys {
/**
* @param args
*/
public static void main(String[] args) {
long startMili=System.currentTimeMillis();
try {
FileInputStream fis = new FileInputStream ("a.mp3");
FileOutputStream fos = new FileOutputStream ("temp.mp3");
byte[] bys = new byte[1024];
int len = 0;
16 while ((len = fis.read(bys)) != -1) {
17 fos.write(bys, 0, len);
18 }
fis.close();
fos.close();
} catch (IOException e) {
e.printStackTrace();
}
long endMili=System.currentTimeMillis();
System.out.println("总耗时为:"+(endMili-startMili)+"毫秒");
}
}

注:红色代码为改进前后的代码对比

运行效果:

Java(四)-LMLPHP


总结:

1. 字节流拷贝文件步骤如下:

①.构造文件字节输入输出流

②.创建一个字节数组,用来指定每次复制的字节大小

③.输入流从源文件读取字节,输出流将字节写入文件

2. fis.read(bys)的作用是从源文件最多读取bys.length字节的数据送给bys数组,返回的是读入的字节总数。

本例中bys.length的长度指定为1024000,当最后一次不足1024000,例如只剩下5000字节时,返回的就是5000,此时所有字节读取完毕。下一次读入时由于已到达文件末尾,返回-1。

fos.write(bys, 0, len)意思是将byte数组从偏移量0开始的n个字节写入文件输出流。

3. 程序结束后要关闭输入输出流。

04-23 01:43