缓存和内存的理解

缓存可以认为是内存的一部分,但是也不能简单地这样认为

缓存是为了解决CPU速度和内存速度的速度差异问题

特别提醒:

1、因为缓存只是内存中少部分数据的复制品,所以CPU到缓存中寻找数据时,也会出现找不到的情况(因为这些数据没有从内存复制到缓存中去),这时CPU还是会到内存中去找数据,这样系统的速度就慢下来了,不过CPU会把这些数据复制到缓存中去,以便下一次再到内存中去取

2、因为随着时间的变化,被访问得最频繁的数据不是一成不变的,也就是说,刚才还不频繁的数据,此时已经需要被频繁的访问,刚才还是最频繁的数据,现在又不频繁了,所以说缓存中的数据要经常按照一定的算法来更换,这样才能保证缓存中的数据是被访问最频繁的

3、关于一级缓存和二级缓存

为了分清这两个概念,我们先了解一下RAM(随机存取存储器)

RAM和ROM相对的,RAM是掉电以后,其中才信息就消失那一种,ROM在掉电以后信息也不会消失那一种

RAM又分两种:

一种是静态RAM,SRAM;一种是动态RAM,DRAM。前者的存储速度要比后者快得多,我们现在使用的内存一般都是动态RAM。

为了增加系统的速度,把缓存扩大不就行了吗?扩大的越大,缓存的数据越多,系统不就越快了吗?

缓存通常都是静态RAM,速度是非常的快

但是静态RAM集成度低(存储相同的数据,静态RAM的体积是动态RAM的6倍)

价格高(同容量的静态RAM是动态RAM的四倍)

由此可见,扩大静态RAM作为缓存是一个非常愚蠢的行为

但是为了提高系统的性能和速度,我们必须要扩大缓存

这样就有了一个折中的方法,不扩大原来的静态RAM缓存,而是增加一些高速动态RAM作为缓存

这些高速动态RAM速度要比常规动态RAM快,但比原来的静态RAM缓存慢

我们把原来的静态RAM缓存叫一级缓存,而把后来增加的动态RAM叫二级缓存

一级缓存和二级缓存中的内容都是内存中访问频率高的数据的复制品(映射),它们的存在都是为了减少高速CPU对慢速内存的访问,通常CPU找数据或指令的顺序是:先到一级缓存中找,找不到再到二级缓存中找,如果还找不到就只有到内存中找了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值