volatile关键字与内存的可见性

1. volatile 关键字 主存可见性

volatile 关键字会让主存的数据可见,在多线程中 修饰共享数据,保证多个线程访问数据的时候,都保证每个线程都可以看见这个主存中的最新数据

volatile 相比 synchronized 是一种轻量级的同步策略

1.volatile 不具备 “互斥性”
2.volatile 不能保证变量的 “原子性”
volatile 加上之后,所有操作会在主存之中进行

这里写图片描述

2.原子变量

i++ 的原子性问题 => 内存可见性
读 -> 改 ->写
jdk1.5之后有 Atomic 类, 原子性
volatile 保证内存可见性, CAS算法 保证了数据的原子性
CAS 硬件对于并发操作共享数据的支持
内存值 A 预估值 V 更新值 B
只有 A == V 才把 A=B 否则不操作

3.模拟CAS算法

发布了64 篇原创文章 · 获赞 11 · 访问量 6万+

猜你喜欢

转载自blog.csdn.net/Summer_i/article/details/79483256
今日推荐