共计 909 个字符,预计需要花费 3 分钟才能阅读完成。
自动写代码机器人,免费开通
丸趣 TV 小编给大家分享一下 linux 中 buffer 和 cache 的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
Buffer 和 Cache 的区别 buffer 与 cache 操作的对象就不一样。
buffer(缓冲)是为了提高内存和硬盘(或其他 I / O 设备)之间的数据交换的速度而设计的。
cache(缓存)是为了提高 cpu 和内存之间的数据交换速度而设计的,也就是平常见到的一级缓存、二级缓存、三级缓存。cpu 在执行程序所用的指令和读数据都是针对内存的,也就是从内存中取得的。由于内存读写速度慢,为了提高 cpu 和内存之间数据交换的速度,在 cpu 和内存之间增加了 cache,它的速度比内存快,但是造价高,又由于在 cpu 内不能集成太多集成电路,所以一般 cache 比较小,以后 intel 等公司为了进一步提高速度,又增加了二级 cache,甚至三级 cache,它是根据程序的局部性原理而设计的,就是 cpu 执行的指令和访问的数据往往在集中的某一块,所以把这块内容放入 cache 后,cpu 就不用在访问内存了,这就提高了访问速度。当然若 cache 中没有 cpu 所需要的内容,还是要访问内存的。
缓冲(buffers)是根据磁盘的读写设计的,把分散的写操作集中进行,减少磁盘碎片和硬盘的反复寻道,从而提高系统性能。linux 有一个守护进程定期清空缓冲内容(即写入磁盘),也可以通过 sync 命令手动清空缓冲。
简单来说,buffer 是即将要被写入磁盘的,而 cache 是被从磁盘中读出来的。buffer 是由各种进程分配的,被用在如输入队列等方面。一个简单的例子如某个进程要求有多个字段读入,在所有字段被读入完整之前,进程把先前读入的字段放在 buffer 中保存。
cache 经常被用在磁盘的 I / O 请求上,如果有多个进程都要访问某个文件,于是该文件便被做成 cache 以方便下次被访问,这样可提高系统性能。
看完了这篇文章,相信你对“linux 中 buffer 和 cache 的示例分析”有了一定的了解,如果想了解更多相关知识,欢迎关注丸趣 TV 行业资讯频道,感谢各位的阅读!
向 AI 问一下细节
丸趣 TV 网 – 提供最优质的资源集合!