Java内存模型(Java Memory Model,JMM)

为什么要有Java内存模型

  • 可见性,由缓存导致的可见性问题。
  • 有序性,由编译优化导致的有序性问题。
  • 原子性,由线程切换导致的原子性问题。

Java内存模型就是为了解决可见性和有序性问题。

什么是Java内存模型(JMM)

注意:JVM内存模型与Java内存模型是两个不一样的东西。

  • JVM内存模型:具体指的是JVM中运行时数据区的分区。
  • JMM是一种规范,是抽象的概念,目的是解决由于多线程并发编程通过内存共享进行通信时,存在的本地内存数据不一致、编译器会对代码指令重排序、处理器会对代码乱序执行等带来的问题,即保证内存共享的正确性(可见性、有序性、原子性)。

JMM是一种抽象的概念,它是一种规范,定义了程序中各个变量访问的方式。JVM运行程序的实体是线程,每个线程创建时JVM会为其创建相应的工作内存(空栈间),用于储存线程私有数据,JMM中规定所有变量都存储在主内存上,所有线程都可访问,线程对于变量的操作(赋值、读取等)必须在工作内存进行,操作完成首在写回主内存,这样个线程之间就无法相互访问,线程间的通信(传值)必须通过主内存来完成。

 

上一篇:设置hive 参数


下一篇:MySQL存储引擎