read()方法我知道是读一个字节,如果用while循环读取的话,为什么他第二次循环的时候就自动read后面的字节了呢?不知道内存里是怎么分配的,解释如下:
如果用while循环读取的话,为什么他第二次循环的时候就自动read后面的字节了呢?
解答:要解释为什么会自动读取后面的字节,首先需要了解大体上文件在硬盘物理结构上的存取方式。这涉及到很多很多专业知识,比如文件系统等,简单来说就是,当你保存文件的时候步骤基本上是:操作系统首先在DIR区中找到空区写入文件名、大小和创建时间等相应信息,然后在Data区找到闲置空间将文件按照簇尽可能找到连续的数据区,依次将写入流从头开始将每个字节进行顺序保存。
当要进行文件的读取时,Java封装的FileInputStream.read方法也会调用操作系统的API依次读取这些数据。在读取文件数据的时候必须是顺序的,不可能说先读取第一个字节,后读取倒数第二个字节。循环读取的时候就read方法将读取的位置++,因此造成每次read都是顺序读取后面的字节,直到遇到文件末尾标记。
另外说一下读取出来的每一个字节在你这个程序中的保存方式:
文件流FileInputStream的读取是单向的,也就是说从第一个字节到最后一个字节。如果文件总共|1|2|3|4|5|个字节,那么文件读取的顺序肯定是12345,假设当前已经读到3,那么接下来要么你停止读取,要么你读取4,不可能再回头读取2和1,也不能直接去读取5。通过in.read()读取出来的数据是个临时变量,java会自动在堆中为它分配一个内存空间,但是当fis.read()执行结束后,垃圾回收器gc会立刻将其删除,因此在这个程序中,读取出来的文件其实只保存了最后一个字节,这个字节放在b变量中。如果你想保存整个文件数据,你可以建立一个与文件长度等长的byte数组。