高速缓存是怎么让CPU找到地址内容的?

这个场景在性能优化下,应该很少会用到。但是还是总结一下。

Input: CPU给的一个地址,例如 0xffads1233423
Out: 这个地址上的值。

WORKFLOW

  • CPU高速缓存高速缓存会拿这个地址的中间几个位置,组成一个key
  • 高速缓存拿着这个keyset里面查找,是否有当前的kley
    • false:
      高速缓存从L2缓存读取这个地址的信息。同时把这个地址后面的一些位子,也一起加载到高速缓存中。 比如,CPU 地址是p1, 高速缓存会把p1,p1+1,p1+2,等加载到缓存行中。至于加载多少,取决于缓存行的大小。

    • true
      高速缓存直接返回给cpu.

Discuss

从这个过程我们可以看到,

  • 为了提高缓存命中率,我们需要尽量使用后面加载进来的地址东西。
  • 对于已经加载到高速缓存的内容,如果他will be used.那么 keep it still there before it will be used.
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值