java while( read)_read()方法我知道是读一个字节,如果用while循环读取的话,为什么他第二次循环的时候就自动read后面的字节了呢?...

这篇博客探讨了文件读取的原理,重点讲解了Java中FileInputStream的read()方法如何按照字节顺序读取文件。内容涉及文件在硬盘上的存储方式、读取过程以及内存中的处理。在循环读取时,read()方法会自动读取下一个字节,直到文件结束。同时,文章还介绍了读取的字节如何在程序中临时保存,以及如何保存整个文件数据的方法。
摘要由CSDN通过智能技术生成

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数组。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值