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

 1 import java.io.FileInputStream;
 2 import java.io.FileOutputStream;
 3 import java.io.IOException;
 4 
 5 public class Yuan {
 6     /**
 7      * @param args
 8      */
 9     public static void main(String[] args) {
10         long startMili=System.currentTimeMillis();
11         try {
12             FileInputStream fis = new FileInputStream ("a.mp3");
13             FileOutputStream fos = new FileOutputStream ("temp.mp3");
14             int read = fis.read();        
15             while ( read != -1 ) {
16                 fos.write(read);    
17                 read = fis.read();
18             }            
19             fis.close();
20             fos.close();
21         } catch (IOException e) {
22             e.printStackTrace();
23         }
24         long endMili=System.currentTimeMillis();
25         System.out.println("总耗时为:"+(endMili-startMili)+"毫秒");
26     }
27 }

 

运行效果:

 

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

 1 import java.io.FileInputStream;
 2 import java.io.FileOutputStream;
 3 import java.io.IOException;
 4 
 5 public class Copys {
 6     /**
 7      * @param args
 8      */
 9     public static void main(String[] args) {
10         long startMili=System.currentTimeMillis();
11         try {
12             FileInputStream fis = new FileInputStream ("a.mp3");
13             FileOutputStream fos = new FileOutputStream ("temp.mp3");    
14             byte[] bys = new byte[1024];
15             int len = 0;
16             while ((len = fis.read(bys)) != -1) {
17                 fos.write(bys, 0, len);
18             }            
19             fis.close();
20             fos.close();
21         } catch (IOException e) {
22             e.printStackTrace();
23         }
24         long endMili=System.currentTimeMillis();
25         System.out.println("总耗时为:"+(endMili-startMili)+"毫秒");
26     }
27 }

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

运行效果:

 

 


 

总结:

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

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

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

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

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

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

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

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