Java Memory Model

1 线程间的通信机制

(1)共享内存:在Java中使用的是共享内存的并发模型。
(2)消息传递

2 Java Memory Model

关于主内存与本地内存之间具体的交互协议,即一个变量如何从主内存拷贝到本地内存、如何从本地内存同步回主内存之类的实现细节,Java内存模型中定义了以下8种操作来完成,Java虚拟机实现时必须保证下面提及的每一种操作都是原子的、不可再分的(对于double和long类型的变量来说,load、store、read和write操作在某些平台上允许有例外)。
(1)lock(锁定):作用于主内存的变量,它把一个变量标识为一条线程独占的状态。
(2)unlock(解锁):作用于主内存的变量,它把一个处于锁定状态的变量释放出来,释放后的变量才可以被其它线程锁定。
(3)read(读取):作用于主内存的变量,它把一个变量的值从主内存传输到线程的本地内存中,以便随后的load操作使用。
(4)load(载入):作用于本地内存的变量,它把read操作从主内存中得到的变量的值放入本地内存的变量副本中。
(5)use(使用):作用于本地内存的变量,它把本地内存中一个变量的值传递给执行引擎,每当虚拟机遇到一个需要使用变量的值的字节码指令时将会执行这个操作。
(6)assign(赋值):作用于本地内存的变量,它把一个从执行引擎接收到的值赋给本地内存的变量,每当虚拟机遇到一个给变量赋值的字节码指令时将会执行这个操作。
(7)store(存储):作用于本地内存的变量,它把本地内存中一个变量的值传送到主内存中,以便随后的write操作使用。
(8)write(写入):作用于主内存的变量,它把store操作从本地内存中得到的变量的值放入主内存的变量中。

3 long和double的非原子性协定

允许Java虚拟机将没有被volatile修饰的64位数据的读写操作划分为两次32位的操作来进行,即允许Java虚拟机实现选择可以不保证64位数据类型的load、store、read和write这4个操作的原子性。
如果有多个线程共享一个并未声明为volatile的long或double类型的变量,并且同时对它们进行读取和修改操作,那么某些线程可能会读取到一个既非原值,也不是其它线程修改值的代表了“半个变量”的数值。
不过这种读取到“半个变量”的情况非常罕见(在目前商用Java虚拟机中不会出现),因为Java内存模型虽然允许虚拟机不把long和double变量的读写实现成原子操作,但允许虚拟机选择把这些操作实现为具有原子性的操作,而且还“强烈建议”虚拟机这样实现。在实际开发中,目前各种平台下的商用虚拟机几乎都选择把64位数据的读写操作作为原子操作来对待,因此我们在编写代码时一般不需要把用到的long和double变量专门声明为volatile。

4 重排序

为提高程序性能,编译器和CPU可能会对没有依赖关系的数据操作进行重排序。
在单线程环境下,重排序不会改变程序的运行结果。
(1)编译器优化重排序:编译器改变代码的执行顺序。
(2)指令重排序:CPU改变机器指令的执行顺序。
(3)内存系统重排序:CPU使用缓存和读写缓冲区,这使得载入和存储操作看起来是乱序执行的。

5 Happens-before

如果一个操作happens-before另一个操作,那么第一个操作的结果对于第二个操作是可见的。
如果两个操作之间存在happens-before关系,并不代表它们在JVM的具体实现必须按照happens-before关系指定的顺序执行。如果重排序之后的执行结果,与按照happens-before关系来执行的结果一致,那么这种重排序并不非法。
(1)如果操作x和操作y位于同一个线程中,在程序顺序上操作x先于操作y,那么x happens-before y。
(2)一个对象构造方法的结尾happens-before这个对象对应的finalize方法的开始。
(3)如果操作x和随后的操作y构成同步,那么x happens-before y。
(4)如果x happens-before y、y happens-before z,那么x happens-before z。
(5)对一个监视器的解锁操作happens-before随后对这个监视器的加锁操作。
(6)对一个volatile字段的写操作happens-before随后对这个字段的读操作。
(7)调用一个线程的start方法happens-before这个线程中的所有操作。
(8)如果线程A调用了线程B的join方法,那么线程B中的所有操作happens-before线程A从线程B的join方法成功返回。
(9)一个对象的默认初始化happens-before程序对这个对象的其它所有操作。
当程序中出现两个没有happens-before关系的操作对同一数据进行访问时,我们将其称为程序中存在数据竞争。
当且仅当所有连续一致的操作都没有数据竞争时,这个程序就是正确同步的。如果一个程序是正确同步的,那么这个程序中的所有操作就会表现出连续一致性。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354