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就不会因为性能考虑而去对指令重排
标签:
- 上一篇: Java学习总结(1.1.3) 线程中止
- 下一篇: Java学习总结(1.1.5) 线程通信
每日一句
如果你能每天呐喊二十一遍「我用不着为这一点小事而烦恼」,你会发现,你心里有一种不可思议的力量。
博客分组
标签云
- 最近综合
- 情绪巨婴是什么 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