您的位置:首页 > Web前端

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

2016-12-26 15:56 288 查看
它的缓存和你自己的缓存不是一个概念。大概流程如下。

使用不带缓存的inputstream时

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

而使用bufferedinputstream时,是这样的

当你创建bufferedinputstream,后他会立即去读数据然后放到jvm管理的内存里,

每次你读取时,他不会再去系统中读取,会去内存中读取数据,之后再判断内存中剩的还多不,不多就再由它去指挥系统读取操作,不论你是读一个字节还是一个数组,系统都不一定会去操作硬盘。

你的程序和数据读取的效率关联就非常微小了。

换个角度想,

如果你用不带buffer的流,打开文件然后立即关闭,系统不会有任何数据调用,关闭会很快执行。

而你用带buffer的流打开文件,哪怕没读取就立即执行关闭了,这个关闭也不会立即执行,而且系统也已经把一部分数据读取的内存了,会比用不带buffer的效率低。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐