废话少说,上代码
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
/**
* @Author:GaoXiaoZhuang
* @Company:ZhongRuan
* @Description:文件复制
*/
public class FileCopyDemo {
public static void main(String[] args) throws IOException {
FileInputStream fis = new FileInputStream("f:\\demo1\\girl.jpg");
FileOutputStream fos = new FileOutputStream("f:\\demo2/girl.jpg");
byte[] bytes = new byte[1024];
int hasread = 0;
while ((hasread = fis.read(bytes)) != -1) {
fos.write(bytes);
}
fis.close();
fos.flush();
fos.close();
}
}
这段代码就是最简单的字节流复制文件,我们设置了一个byte类型的数组,用来作为存储文件字节码的容器,我们的起始文件大小大概率是不会被1024整除的,所以当文件拷贝的最后一次小于1024个字节的时候,会把空的字节写入到目的文件中,所以最终的目的文件字节数一定会被1024整除,就这样变大了一点点。
这个时候,小可爱们就说啦,我们让数组长度为1,肯定就不会变大了,你咋那么聪明,就是不会变大呀,但是我们设置数组的目的是什么呢?无参read方法默认就是一次读取一个字节,创建byte数组就是为了提高执行效率,也不能够太大,一样会影响执行效率。
那咋整?
可以使用InputStream.available()这个方法,在读写操作前先得知数据流里有多少个字节可以读取。
但是如果这个方法用在从本地文件读取数据时,一般不会遇到问题。但如果是用于网络操作,就经常会遇到一些麻烦。比如,Socket通讯时,对方明明发来了1000个字节,但是自己的程序调用available()方法却只得到900,或者100,甚至是0,感觉有点莫名其妙,怎么也找不到原因。其实,这是因为网络通讯往往是间断性的,一串字节往往分几批进行发送。本地程序调用available()方法有时得到0,这可能是对方还没有响应,也可能是对方已经响应了,但是数据还没有送达本地。对方发送了1000个字节给你,也许分成3批到达,这你就要调用3次available()方法才能将数据总数全部得到。