讲一讲cpu缓存和指令重排序

为了弥补cpu的计算速度和内存的读写速度的差距,cpu通过引入三级缓存来充分发挥cpu的性能

一级缓存  离cpu最近,容量最小,读写速度最快,逻辑核独占

二级缓存  离cpu次之,容量居中,读写速度居中,物理核独占

三级缓存  离cpu最远,容量最大,读写速度最慢,cpu独占

而缓存也导致了缓存的一致性问题,这个通过MESI协议进行解决

为了充分利用cpu,减少等待时间,还引入了指令重排序的机制,

在此之前,先说一下as-if-serial,主要就是指指令的重排序不会影响最终结果的产生

 所以在cpu遇到执行指令需要等待的情况,在遵循as-if-serial协议的基础上,可能会先执行下一条指令,从而减少等待时间,提升性能,这也带来了在多线程情况下有可能引起的乱序问题

这里引入了内存屏障的概念加以解决

分为读屏障和写屏障

写屏障强制cpu写回主内存后才能执行后面的指令

读屏障强制cpu回主内存读取数据后才能执行后面的指令

 无论是cpu缓存或指令重排序,都是为了让cpu不闲下来,压榨完cpu最后一滴计算能力

而MESI,内存屏障 等概念则补齐了由上面的机制引发的一些问题,从而完善这一机制.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值