Java 内存模型(JMM)
定义:JMM 是一种规范,它规范了 Java 虚拟机与计算机内存之间是如何协同工作的,它规定了一个线程是如何和何时可以看到其它线程修改过的共享变量的值,以及如何同步共享变量的值。
当一个线程可以访问这个对象的时候,他也可以访问这个对象的成员变量,如果两个线程同时调用同一个对象上的同一个方法,他们将都会访问这个对象的成员变量,但是每一个线程都拥有了这个变量的私有拷贝(变量副本)。
假设主内存中变量的值为 1,线程 A 和 B 同时执行。线程 A 从主内存中拿到的值是 1,存入自己的本地内存中,然后执行 + 1 的操作结果为 2,然后将 2 写回主内存中。同时线程 B 从主内存中拿到的值也是 1,存入线程 B 的本地内存中 + 1 结果也是 2,写入主内存,而不是读取线程 A 的结果之后在进行计算,这两个线程间的数据是不可见的,因此计数就出现了错误,这个时候就需要添加一些同步手段,来保证并发时程序处理的准确性。
JMM – 线程同步的八种操作
lock(锁定)
lock:作用于主内存的变量,把一个变量标示为一条线程独占状态
unlock(解锁)
unlock:作用于主内存变量,把一个处于锁定状态的变量释放出来,释放后的变量才可以被其他线程锁定
read(读取)
read:作用于主内存变量,把一个变量值从主内存传输到线程的工作内存中,以便随后的 load 动作使用
load(载入)
load:作用于工作内存的变量,他把 read 操作从主内存中得到的变量值放入工作内存的变量副本中
use(使用)
use:作用于工作内存变量,把工作内存中的一个变量值传递给执行引擎
assign(赋值)
assign:作用于工作内存变量,他把一个从执行引擎接收到的值赋值给工作内存变量
store(存储)
store:作用于工作内存变量,把工作内存中的一个变量值传递到主内存中,一边随后的写操作
write(写入)
write:作用于主内存变量,他把 store 操作从工作内存中一个变量的值传递到主内存的变量中