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以方便下次被访问,这样可提高系统性能。
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/2382.html
服务器部署程序员系统优化网站设置运维相关文章
- 给程序员的营销课:提升下单率,首先从图标开始!
- Scratch3.0——助力新进程序员理解程序(十三、音乐)
- linux 使用socket代理详解程序员
- Linux命令速查手册(第2版)学习详解程序员
- for循环、while循环区别详解程序员
- useradd -g 和-G的区别&用户信息存放的文件信息详解程序员
- 四层和七层负载均衡的区别详解程序员
- SecureCRT中sz和rz区别详解程序员
- nginx配置ssl证书实现https访问详解程序员
- Nginx reload和restart区别详解程序员
- git之解决每次拉取、提交代码时都需要输入用户名和密码详解程序员
- dede无子栏目的栏目直接调用顶级栏目(不让调用的解决方法) noself=/’yes/’详解程序员
- mvn命令着中package、install、deploy的区别详解程序员
- linux保留旧版本python,安装python3详解程序员
- Windows:FTP命令大全详解程序员
- FileBeat安装配置详解程序员
- CentOS中Ctrl+Z、Ctrl+C、Ctrl+D的区别详解程序员
- Linux — SSH远程登陆配置sshd_config文件详解程序员
- Linux date命令详解程序员
- Windows Azure Azure 简介详解程序员
- 三大UML建模工具Visio、Rational Rose、PowerDesign的区别详解程序员
- 为什么需要创建型模式以及简单工厂模式(三)详解程序员
- 在Linux终端管理文件你要知道的11个命令详解程序员
- 如何使用CBO,CBO与RULE的区别详解程序员
- java实现栈详解程序员
- AI 是核心战略,全球前五的目标不会变详解程序员