下面的代码可以实现以字节为单位复制文件的功能,适合复制非文本类型的文件,为了更清楚的观测运行速率,我加入了程序计时器,代码如下:
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. 程序结束后要关闭输入输出流。