IO流-07:缓冲流

一、什么是缓冲流?

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

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

二、缓冲字节流

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

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

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

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

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

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

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

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

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

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

举例:

4、总结

①缓冲流有几种?

四种。

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

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

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

③缓冲字节流如何使用?

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

三、缓冲字符流

相关推荐
素材积累2 小时前
博士后出站来深可申请的项目补贴等
数据库
_1_73 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
basketball6164 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存
李可以量化4 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
汽车仪器仪表相关领域5 小时前
南华 NHAT-610 柴油车排放测试仪 产品详解
数据库·功能测试·汽车·压力测试·可用性测试
我滴老baby6 小时前
工业时序数据实战:基于 DolphinDB 流计算引擎的实现与调优
数据库
睡不醒男孩0308237 小时前
TiDB数据库调研
数据库·tidb
珠***格7 小时前
实操落地|防逆流装置的安装规范、调试标准与故障处置
网络·数据库·人工智能·分布式·能源·边缘计算
Omics Pro8 小时前
3种蛋白结构输入方式!已申报欧洲发明专利
数据库·人工智能·python·机器学习·plotly
itfallrain9 小时前
Spring 构造器循环依赖排查:@RequiredArgsConstructor + @Lazy 到底有没有生效
数据库·python·spring