1 缓冲(Buffer) 和缓存(Cache)区别和联系.
2 区别: 两者操作的对象不一样.
(1) buffer(缓冲): 是为了提高 内存和硬盘或其他I/0设备 之间的数据交换的速度而设计的.
当创建buffer对象时, 会先创建一个缓冲区数组. 然后当我们读一个文件时, 先从硬盘中读到缓冲区, 待缓冲区 满后 再进行传送. 这样会大大减少读写次数,这样就可以节省很多时间, 效率会更高.
(2) cache(缓存) 是为了提高 cpu和内存 之间的数据交换速度而设计.
高速缓冲存储器, 读写速度很快,几乎与CPU一样。由于CPU的运算速度太快,内存的数据存取速度无法跟上CPU的速度,所以在cpu与内存间设置了cache为cpu的数据快取区。当计算机执行程序时,数据与地址管理部件会 预测 可能要用到的数据和指令, 并将这些数据和指令预先从内存中读出送到Cache. 一旦需要时,先检查Cache,若有就从Cache中读取,若无再访问内存,现在的CPU还有一级cache,二级cache。简单来说,Cache就是用来解决CPU与内存之间速度不匹配的问题,避免内存与辅助内存频繁存取数据,这样就提高了系统的执行效率. 设置缓存的理论基础, 是程序访问的局部性原理. 缓存的功能均由硬件实现,对程序员是透明的.
(3) buffer偏重于写, 而cache偏重于读.
3 相同点: 两者都加快了系统的反应速度.
4 举例:
缓冲:我们倒垃圾的时候,不可能一有垃圾就直接跑去垃圾站倒垃圾吧。而是先把垃圾倒到垃圾桶,垃圾桶满了再一起倒到垃圾站。其中垃圾桶就是这个缓冲容器。得到缓冲池满了,再一起处理。其实这和我们的缓冲流一样,都有一个buffer。很多中间件都有这个有。其实就是为了减少io操作次数,提高效率。
缓存: 我们生活中看视频就是个最好的例子, 比如我要看《神雕侠侣》,如果我没有下载。则需要我先从远程服务器下载好到本地。那么我以后需要看《神雕侠侣》的时候,之间本地看就行了。本地的《神雕侠侣》就相当于一个缓存容器.