bufferedinputstream也需要指定一个数组长度呀?

它的缓存和你自己的缓存不是一个概念。大概流程如下。

使用不带缓存的inputstream时
每次你读取时,系统执行读取操作把数据读出来,你指定读一个字节那就读一个字节,指定一个数组那就读一个数组的,你的程序和数据的读取效率有非常大的关系。

而使用bufferedinputstream时,是这样的
当你创建bufferedinputstream,后他会立即去读数据然后放到jvm管理的内存里,
每次你读取时,他不会再去系统中读取,会去内存中读取数据,之后再判断内存中剩的还多不,不多就再由它去指挥系统读取操作,不论你是读一个字节还是一个数组,系统都不一定会去操作硬盘。
你的程序和数据读取的效率关联就非常微小了。

换个角度想,
如果你用不带buffer的流,打开文件然后立即关闭,系统不会有任何数据调用,关闭会很快执行。
而你用带buffer的流打开文件,哪怕没读取就立即执行关闭了,这个关闭也不会立即执行,而且系统也已经把一部分数据读取的内存了,会比用不带buffer的效率低。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值