Java学习总结(1.1.4) 内存屏障和CPU缓存

精贴 置顶
1912 0
作者:      发布时间: 2020-03-18 11:06:51

内存屏障和CPU缓存

 

CPU -> L1 Cache -> L2 -> L3 -> 内存

 

 

MESI协议,它规定每条缓存有个状态位,同时定义了下面四个状态:

修改态( Modified)-此 cache行已被修改过(脏行),内容已不同于主存,为此 cache专有;

专有态( Exclusive)ー此 cache行内容同于主存,但不出现于其它 cacher中;

共享态( Shared)-此 cache行内容同于主存,但也出现于其它 cache中;

无效态( Invalid)ー此 cache行内容无效(空行)。

 

 

 

处理器提供了两个内存屏障指令( Memory Barrier)用于解決上述两个问题

写内存屏障( Store Memory Barrier):在指令后插入 Store Barrier,能让写入缓存中的最新数据更新写入主内存,让其他线程可见。

强制写入主内存,这种显示调用,CPU就不会因为性能考虑而去对指令重排

 


标签:

每日一句

如果你能每天呐喊二十一遍「我用不着为这一点小事而烦恼」,你会发现,你心里有一种不可思议的力量。

标签云

vue
最近综合
情绪巨婴是什么 12.18
普通蛋糕做法 05.31
玉米烤肠芝士面包做法 05.31
Mysql安装教程 - 绿色版 06.18
我们学习知识为什么总是忘记呢?【学习金字塔】 05.12
Typora开发版⽆法使⽤解决⽅法 05.04
为什么无知者越自信? -- 达克效应 05.10
马斯洛需求层次理论 04.29
随机综合
Java学习总结(1.3.3) 并发容器类2 04.09
情绪巨婴是什么 12.18
Java学习总结(1.2.1) Java内存模型详解 03.18
Java学习总结(2.1.2) BIO阻塞网络编程 04.17
Spring返回json可以跨域设置 08.21
中间件1.2.2-ActiveMQ支持的消息协议讲解 04.23
vue的安装和配置 08.05
[vue]VUE的一些问题和解决 08.05