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确保线程读取到的值是最新的.

猜你喜欢

转载自blog.csdn.net/wzj_whut/article/details/86774622