废话少说,上代码

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()方法才能将数据总数全部得到。