IO流-07:缓冲流

一、什么是缓冲流?

前面学的四种流,都有对应的缓冲流,来改善原来的性能,如下:

这四种缓冲流,都改善了原来对应流的性能。好比一台改装车,性能更加强劲了。

二、缓冲字节流

1、不使用缓冲字节流的情景

如下图,我们想要从D盘,复制一个16KB大小的文件,到C盘。

我们定义的字节数组(一个小桶)长度是1KB。

这样,输入到内存中,需要调用磁盘16次;输出到文件,需要调用磁盘16次。

这样一来,需要调用磁盘IO操作32次。很频繁,并且磁盘速度很慢,会拖累内存的速度,因此此时性能不好。

2、使用缓冲字节流的情景

此时,设置一个缓冲池(可以理解为一个大桶,容量为8KB),我们每次从磁盘读的字节,都存入这个大桶。这样只需要调用磁盘2次。输出时,也是从大桶往文件里写,也需要调用磁盘2次。

这样一来,只需要调用磁盘4次,缩短了和磁盘交流的次数,降低了磁盘对内存的速度影响,从而提高了IO性能。

综上,缓冲字节流的作用:降低调用磁盘的次数,提高性能。

3、如何将原来的流,包装成缓冲流?

举例:

4、总结

①缓冲流有几种?

四种。

  • 缓冲字节输入流:BufferedInputStream
  • 缓冲字节输出流:BufferedOutputStream
  • 缓冲字符输入流:BufferedReader
  • 缓冲字符输出流:BufferedWriter

②缓冲字节流为什么提高了字节流读写数据的性能?

缓冲字节流,自带了8KB的缓冲区,可以较少调用磁盘的次数,从而降低磁盘(速度慢)对内存(速度快)的影响。因此会提高读取数据的性能。

③缓冲字节流如何使用?

缓冲流功能上和原来并无很大差异,但是确实提高了性能。

三、缓冲字符流

相关推荐
笃行35014 小时前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行35014 小时前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行35014 小时前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB1 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶2 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵2 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils2 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
Databend3 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
ClouGence4 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle