使用缓冲流(处理流)为什么速度会加快?

一开始学习处理流会疑问为什么速度会加快呢?好比一个10KB的文件。使用最基本的字节流读写,只要读一次10KB到内存。存一次10KB到目标文件就行了。但是使用缓冲不是要读1次10KB到缓冲,再从缓冲写一次10KB到CPU,再从CPU写10KB到缓冲,再从缓冲10KB到目标文件吗?明显过程长的!

其实不然!如下:

首先为什么要设置缓冲?

如果不设置缓冲的话,CPU取一个存一个。设置缓冲区的话:就好比是把基础流用DMA方式包装起来如下:

CPU通常会使用 DMA 方式去执行 I\O流 操作。CPU 将这个工作交给DMA控制器来做,自己腾出时间做其他的事,当DMA完成工作时,DMA会主动告诉CPU“操作完成”。这时,CPU接管后续工作。在此,CPU 是被动的。DMA是专门 做 I\O 与 内存 数据交换的,不仅自身效率高,也节约了CPU时间,CPU在DMA开始和结束时做了一些设置罢了。 缓冲区就是内存里的一块区域,把数据先存内存里,然后一次性写入,类似数据库的批量操作,显然效率比较高。还节省CPU的使用。

总结:使用缓冲处理流包装就是一堆一堆的干活,还能不用CPU多次处理数据转换,只是设置一下数据转换成功后的文件。

     不使用缓冲处理流包装就是CPU傻傻的一个字节一个字节循环来干活存储写入文件中,相比可见效率明显变慢。

你可能感兴趣的:(一些记录)