码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-06-27 00:32:55      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:mode   bmc   --   创建   uml   共享内存区   lin   com   gil   

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

线程之间如何通信及线程之间如何同步。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)

标签:mode   bmc   --   创建   uml   共享内存区   lin   com   gil   

原文地址:https://www.cnblogs.com/wjh123/p/11094622.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!