Java内存模型讲了什么java memory model,volatile

资料

Java Memory Model官方文档JSR 133. (注意: 本文不是JVM内存模型)
https://download.oracle.com/otndocs/jcp/memory_model-1.0-prd-oth-G-F
cpu cache对并发编程的影响
https://blog.csdn.net/wzj_whut/article/details/86774650

参考
http://tutorials.jenkov.com/java-concurrency/java-memory-model.html

Thread Stack与Heap

简单来说, 局部变量stack上, 对象heap上. 对编程老手来说, 已经没什么好区分的了.

public class StackAndHeap {
    public static class MyObject{
        public int ivar;
        public Object obj = new Object();
    }

    public static void main(String[] args){
        int localVar1;
        MyObject locaVar2 = new MyObject();
    }
}

上面的代码中
localVar1, locaVar2是局部变量, 在stack
MyObject中的所有成员变量都在heap

Happens-Before

描述了以下这个问题:
两个线程同时访问或修改同一个变量, 哪个先执行, 加个后执行? 造成的影响是什么?
不光是java, 其它编程语言, 只要涉及到多线程编程, 都需要考虑这个问题.
java提供了synchronized, volatile, 以及各种, 来解决这个问题.
synchronized的底层实现估计是hotspot中的synchronizer.cpp, 看不懂
对于新手来说, 才需要认真看. 具体的东西真没啥好说的了, 多写写代码就够了

volatile

需要先了解CPU缓存问题
https://blog.csdn.net/wzj_whut/article/details/86774650
CPU修改cache中的值之后, 需要调用一次回写操作指令, 才能将变化的值回写到内存中.
变量前加了volatile之后, 每次修改变量的值, 都会执行一次回写操作, 其它线程读取这个值时, 会发现cache失效, 然后重新从内存中加载.
简单来说: volatile确保线程读取到的值是最新的.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值