java面试-Java内存模型(JMM)

Posted wjh123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java面试-Java内存模型(JMM)相关的知识,希望对你有一定的参考价值。

一、并发编程两个关键问题

线程之间如何通信及线程之间如何同步。java并发采用的是共享内存模型

二、JMM内存模型
Java内存模型(即Java Memory Model,简称JMM)本身是一种抽象的概念,并不真实存在,它描述的是一组规则或规范,通过这组规范定义了程序中各个变量(包括实例字段,静态字段和构成数组对象的元素)的访问方式。

从抽象的角度来看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(Main Memory)中,每个线程都有一个私有的本地

内存(Local Memory),本地内存中存储了该线程读/写共享变量的副本。

 

三、JMM内存模型特性

1、保证可见性:

由于JVM运行程序的实体是线程,而每个线程创建时JVM都会为其创建一个工作内存(有些地方称为栈空间),用于存储线程私有的数据,而Java内存模型中规定所有变量都存储在主内存,主内存是共享内存区域,所有线程都可以访问,但线程对变量的操作(读取赋值等)必须在工作内存中进行,首先要将变量从主内存拷贝的自己的工作内存空间,然后对变量进行操作,操作完成后再将变量写回主内存,不能直接操作主内存中的变量,工作内存中存储着主内存中的变量副本拷贝,前面说过,工作内存是每个线程的私有数据区域,因此不同的线程间无法访问对方的工作内存,线程间的通信(传值)必须通过主内存来完成,其简要访问过程如下图:

技术图片

如果线程A与线程B之间要通信的话,必须要经历下面2个步骤。

1)线程A把本地内存A中更新过的共享变量刷新到主内存中去。

2)线程B到主内存中去读取线程A之前已更新过的共享变量。

 

 

JMM关于同步的规定:
a、线程解锁前,必须把共享变量的值刷新回主内存
b、线程加锁前,必须读取主内存的最新值到自己的工作内存
c、加锁解锁是同一把锁
 

以上是关于java面试-Java内存模型(JMM)的主要内容,如果未能解决你的问题,请参考以下文章

面试官:说说什么是 Java 内存模型(JMM)?

带你整理面试过程中关于 Java 的内存模型 JMM(Java Memory Model)的相关知识

华为面试官问我关于“多线程之内存模型”,看完这篇,自信满满!

JMM内存模型

java内存模型的JMM简介

Java多线程和并发,JMM(Java内存模型)