第223天学习打卡(知识点回顾 volatile JMM)
Posted 豆豆tj
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第223天学习打卡(知识点回顾 volatile JMM)相关的知识,希望对你有一定的参考价值。
volatile
volatile是java虚拟机提供的轻量级的同步机制。
特点:
-
保证可见性
-
不保证原子性
-
禁止指令重排
volatile禁止指令重排:
计算机在执行程序时,为了提高性能。编译器和处理器常常会对指令进行重排,一般分为以下三种:
源代码--------->编译器优化的重排---------->指令并行的重排---------->内存系统的重排------->最终执行的指令
单线程环境里面确保程序最终执行结果和代码顺序执行的结果一致。
处理器在进行重排序时必须要考虑指令间的数据依赖性
多线程环境中线程交替执行,由于编译器优化重排的存在,两个线程中使用的变量能否保证一致性是无法确定的,结果无法预测。
volatile实现禁止指令重排优化,从而避免多线程环境下程序出现乱序执行的现象。
内存屏障(Memory Barrier)又称为内存栅栏,是一个CPU指令,它的作用有两个:
-
保证特定操作的执行顺序
-
保证某些变量的内存可见性(利用该特性实现volatile的内存可见性)
不保证原子性就可能出现写丢失的情况。
JMM(java内存模型)
JMM(java内存模型Java Memory Model,简称JMM)本身是一种抽象的概念,并不真实存在,它描述的是一组规则或者规范,通过这组规范定义了程序中各个变量(包括实例字段,静态字段和构造数组对象的元素)的访问方式。
JMM关于同步的规定:
-
线程解锁前,必须把共享变量的值刷新回主内存
-
线程加锁前,必须读取主内存的最新值到自己的工作内存
-
加锁解锁是同一把锁
由于JVM运行程序的实体是线程,而每个线程创建时JVM都会为其创建一个工作内存(有些地方称为栈空间),工作内存是每个线程的私有数据区域,而Java内存模型中规定所有变量都存储在主内存,主内存是共享内存区域,所有线程都可以访问,但线程对变量的操作(读取赋值等)必须在工作内存中进行,首先要将变量从主内存拷贝到自己的工作内存空间,然后对变量进行操作,操作完成后再将变量写回主内存,不能直接操作主内存中的变量,各个线程中的工作内存中存储着主内存中的变量副本拷贝,因此不同的线程间无法访问对方的工作内存,线程间通信(传值)必须通过主内存来完成。
JMM三大特性
-
可见性
-
原子性
-
有序性
B站
以上是关于第223天学习打卡(知识点回顾 volatile JMM)的主要内容,如果未能解决你的问题,请参考以下文章
第234天学习打卡(知识点回顾volatile 2 CAS)
第280天学习打卡(知识点回顾 volatile和synchronized的区别)
第300天学习打卡(知识点回顾 hashmap如何实现线程安全)