跳到主要内容

16、Java并发编程 - JMM详解

16、JMM详解

什么是JMM

JMM是一个抽象的概念!并不真实存在!它是一组规范!

程序会跑在不同的操作系统、不同的硬件上,可能在你的电脑上运行完好,在运维那边运行就报错!这些都是底层操作系统、硬件不同引起的,为了屏蔽操作系统底层的差异,提出JMM模型。

JMM:Java Memory Model ,Java内存模型要求必须满足以下条件:

1、线程解锁前,必须要把共享的变量值刷新回主内存;
2、线程加锁前,必须读取主内存的最新值到自己的工作内存;
3、必须是同一把锁!

JMM的内存模型

Java 内存模型对主内存与工作内存之间的具体交互协议定义了八种操作,具体如下:

  • lock(锁定):作用于主内存变量,把一个变量标识为一条线程独占状态。
  • unlock(解锁):作用于主内存变量,把一个处于锁定状态的变量释放出来,释放后的变量才可以被其他线程锁定。
  • read(读取):作用于主内存变量,把一个变量从主内存传输到线程的工作内存中,以便随后的 load 动作使用。
  • load(载入):作用于工作内存变量,把 read 操作从主内存中得到的变量值放入工作内存的变量副本中。
  • use(使用):作用于工作内存变量,把工作内存中的一个变量值传递给执行引擎,每当虚拟机遇到一个需要使用变量值的字节码指令时执行此操作。
  • assign(赋值):作用于工作内存变量,把一个从执行引擎接收的值赋值给工作内存的变量,每当虚拟机遇到一个需要给变量进行赋值的字节码指令时执行此操作。
  • store(存储):作用于工作内存变量,把工作内存中一个变量的值传递到主内存中,以便后续 write 操作。
  • write(写入):作用于主内存变量,把 store 操作从工作内存中得到的值放入主内存变量中。