时间:2021-05-19
多线程的可见性
一个线程对共享变量值的修改,能够及时的被其他线程看到。
共享变量
如果一个变量在多个线程的工作内存中都存在副本,那么这个变量就是这几个线程的共享变量。
Java内存模型
JMM(Java Memory Model,简称JMM)描述了Java程序中各种变量(线程共享变量)的访问规则,以及在JVM中将变量存储到内存和从内存中读取出变量这样的底层细节。它遵循四个原则:
共享变量可见性实现的原理
线程1对共享变量的修改要想被线程2及时看到,必须经过如下2个步骤:
Java的内存模型:
Java语言层面支持的可见性实现方式有以下两种:
synchronized
JMM关于synchronized的规定:
因此线程执行synchronized代码执行互斥锁的过程:
synchronize在JDK6之后,不单单是互斥锁。
volatile
不能保证原子性,但适合使用volatile修饰状态标记量
通过加入内存屏障和禁止重排序优化来实现的
通俗地讲:volatile变量在每次被线程访问时,都强迫从主内存中重读该变量的值,而当该变量发生变化时,又会强迫将最新的值刷新到主内存。这样任何时刻,不同的线程总能看到该变量的最新值。
volatile写操作:
volatile读操作:
多线程的有序性
在Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。
指令重排序:代码书写的顺序与实际执行的顺序不同,指令重排序是编译器或者处理器为了提高程序性能而做的优化。
happens-before原则
JMM可以通过happens-before关系向程序员提供跨线程的内存可见性保证(如果A线程的写操作a与B线程的读操作b之间存在happens-before关系,尽管a操作和b操作在不同的线程中执行,但JMM向程序员保证a操作将对b操作可见)。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前面一篇文章在介绍Java内存模型的三大特性(原子性、可见性、有序性)时,在可见性和有序性中都提到了volatile关键字,那这篇文章就来介绍volatile关
一、多线程三大特性多线程有三大特性:原子性、可见性、有序性。原子性(跟数据库的事务特性中的原子性类似,数据库的原子性体现是dml语句执行后需要进行提交):理解:
在原子性、可见性、有序性中,volatile关键字主要在可见性中发挥作用。volatile声明的变量对所有线程来说是可见的,就是说当变量的值发生改变的时候,其他
背景:听说VolatileJava高阶语法亦是挺进BAT的必经之路。Volatile:volatile同步机制又涉及Java内存模型中的可见性、原子性和有序性,
一、volatile关键字的语义分析1.保证可见性对共享变量的修改,其他线程能够马上感知到。但不能保证原子性(i++)2.保证有序性3.volatile的原理和