为了弥补cpu的计算速度和内存的读写速度的差距,cpu通过引入三级缓存来充分发挥cpu的性能
一级缓存 离cpu最近,容量最小,读写速度最快,逻辑核独占
二级缓存 离cpu次之,容量居中,读写速度居中,物理核独占
三级缓存 离cpu最远,容量最大,读写速度最慢,cpu独占
而缓存也导致了缓存的一致性问题,这个通过MESI协议进行解决
为了充分利用cpu,减少等待时间,还引入了指令重排序的机制,
在此之前,先说一下as-if-serial,主要就是指指令的重排序不会影响最终结果的产生
所以在cpu遇到执行指令需要等待的情况,在遵循as-if-serial协议的基础上,可能会先执行下一条指令,从而减少等待时间,提升性能,这也带来了在多线程情况下有可能引起的乱序问题
这里引入了内存屏障的概念加以解决
分为读屏障和写屏障
写屏障强制cpu写回主内存后才能执行后面的指令
读屏障强制cpu回主内存读取数据后才能执行后面的指令
无论是cpu缓存或指令重排序,都是为了让cpu不闲下来,压榨完cpu最后一滴计算能力
而MESI,内存屏障 等概念则补齐了由上面的机制引发的一些问题,从而完善这一机制.