IO流-07:缓冲流

一、什么是缓冲流?

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

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

二、缓冲字节流

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

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

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

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

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

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

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

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

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

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

举例:

4、总结

①缓冲流有几种?

四种。

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

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

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

③缓冲字节流如何使用?

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

三、缓冲字符流

相关推荐
2401_895521341 小时前
MySQL中的count函数
数据库·mysql
.小小陈.1 小时前
MySQL 入门到实战:从基础概念到核心存储引擎
数据库·mysql
IT邦德2 小时前
Oracle 26ai 首发季度补丁 23.26.2.0.0 来了!单机版升级
数据库·oracle
yoyo_zzm2 小时前
Laravel10.x新特性全解析
数据库·mysql·架构
许彰午2 小时前
CacheSQL(五):桥接篇
java·数据库·缓存·系统架构
七夜zippoe2 小时前
# DolphinDB分区策略:RANGE分区详解
数据库·策略·分区·range·dolphindb
地球资源数据云2 小时前
中国陆地生态系统主要植物功能特征空间分布数据
大数据·数据库·人工智能·机器学习
吠品2 小时前
高性能JS数组操作:何时选用push、unshift、splice或扩展运算符?
linux·服务器·数据库
洛水水2 小时前
【Redis入门】一篇详解Redis五大数据结构
数据结构·数据库·redis