Java内存模型
Java内存模型(Java Memory Model)JMM主要是为了规定线程和内存之间的一些关系。根据JMM的设计,系统存在一个主内存,Java中所有变量都储存在主存中,对于所有线程都是共享的。每条线程都有自己的工作内存,工作内存中保存的是主存中某些变量的拷贝,线程对所有变量的操作都是在工作内存中进行,线程之间无法相互直接访问,变量传递均需要通过主内存完成。
关于主内存与工作内存之间的具体交互协议,即一个变量如何从主内存拷贝到工作内存,如何从工作内存同步回主内存子类的细节实现,JMM定义了八种原子操作:
(1)lock(锁定):作用于主内存的变量,把一个变量标识为线程独占的状态
(2)unlock(解锁):作用于主内存的变量,把一个处于锁定的状态释放出来
(3)read(读取):作用于主内存的变量,把一个变量的值从主内存传输到线程的工作内存
(4)load(载入):作用于工作内存的变量,把read操作从主内存得到的变量值放入工作内存的变量副本中
(5)use(使用):作用于工作内存的变量,把工作内存中一个变量的值传递给执行引擎,每当虚拟机遇到一个需要使用到变量的值的字节码指令时将会执行这个操作
(6)assign(赋值):作用于工作内存的变量,把一个从执行引擎接收到的值赋值给工作内存中的变量,每当虚拟机遇到一个给变量赋值的字节码指令时执行这个操作
(7)store(存储):作用于工作内存的变量,把工作内存中的一个变量的值传递到主内存,以便write操作使用
(8)write(写入):作用于主内存的变量,把store操作从工作内存中得到的变量放入主内存的变量中