1、字节流缓冲区
package com.example;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import java.io.OutputStream;public class MyFileByteData {public static void main (String [] args) throws IOException {//创建一个字节流,用于读取当前目录下的source文件夹中的压缩文件InputStream in=new FileInputStream("/home/lumeng/practise_lum/uml_tmp_file.rar");//创建一个文件字节输出流,用于将读取的数据写入test目录OutputStream out= new FileOutputStream("/home/lumeng/practise_lum/test/uml_tmp_file.rar");byte [] buff=new byte[1024]; //定义一个字节数组,作为缓冲区int len; //定义一个int类型的变量len,记住每次读取的一个字节long begintime=System.currentTimeMillis();//获取拷贝文件前的系统时间while ((len=in.read(buff))!=-1){ //读取一个字节并判断是不是读到文件结尾out.write(buff,0,len);//从第一个字节开始,向文件写入len个字节}long endtime=System.currentTimeMillis();//获取文件拷贝结束时的系统时间System.out.println("拷贝文件所消耗的时间是:"+((endtime-begintime)/1000)+"秒");in.close();out.close();}}
在拷贝的过程中,使用while循环语句,逐渐实现字节文件的拷贝,每循环一次,就从文件读取若干字节填充字节数组,并通过len记住读入数组的字节数,然后从数组的第一个字节开始,将len字节依次写入文件。循环往复,当len的值为-1时,说明已经读到了文件的末尾,循环结束,整个拷贝过程结束。我们可以看出这种操作比单纯字节留拷贝快很多。
2、字节缓冲流
package com.example;import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.IOException;public class MyBuffStream {public static void main (String [] args) throws IOException {//创建一个带缓冲区的输入流BufferedInputStream bis=new BufferedInputStream(new FileInputStream("/home/lumeng/practise_lum/test.txt"));//创建一个带缓冲区的输出流BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream("/home/lumeng/practise_lum/test_out.txt"));int len;while((len=bis.read())!=-1){bos.write(len);}bis.close();bos.close();}}
创建BufferedInputStream和BufferedOutputStream两个缓冲流对象,这两个流都对应了一个大小为8192的字节数组,当调用read()或者write()方法读写数据时,首先将读写的数据存入定义好的字节流数组,然后将字节数组的数据一次性的读写到文件中。
参考文档:
Java基础入门传智博客高教产品研发部
本人郑重声明,本博客所著文章、图片版权归权利人持有,本博只做学习交流分享所用,不做任何商业用途。访问者可將本博提供的內容或服务用于个人学习、研究或欣赏,不得用于商业使用。同時,访问者应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人的合法权利;如果用于商业用途,须征得相关权利人的书面授权。若以上文章、图片的原作者不愿意在此展示內容,请及时通知在下,將及时予以刪除。