博客
关于我
volatile 关键字
阅读量:386 次
发布时间:2019-03-05

本文共 965 字,大约阅读时间需要 3 分钟。

volatile是Java虚拟机提供的轻量级的同步机制。其中它的功能主要有以下两种:

  • 保证被 volatile 修饰的共享变量对所有线程总数可见的,也就是当一个线程修改了一个被 volatile 修饰共享变量的值,新值总是可以被其他线程立即得知

  • 禁止指令重排序优化

从上面也就可以看出,volatile 主要保证对象元素的可见性和有序性。

volatile 基于内存屏障实现、其中它是一个 CPU 指令,主要作用有两个:

  • 保证特定操作的执行顺序(禁止重排序)

  • 保证某些变量的内存可见性(保证可见性)

volatile 会告诉编译器和 CPU,无论执行任何语句都不能和这条指令重排序,并且强制刷出 CPU 的缓存数据,确保任何 CPU 上的线程读取到的是最新版数据。

public class LazySingleton {       private static volatile LazySingleton singleton = null;    private LazySingleton() {       }    public static LazySingleton getSingleton() {           if (singleton == null) {               synchronized (LazySingleton.class) {                   if (singleton == null) {                       singleton = new LazySingleton();                }            }        }        return singleton;    }}

上面是单例模式的 Double-Check 实现,其中变量 singleton 必须通过 volatile 修饰。我们假设对象的创建分以下三步:

1、分配内存空间

2、初始化对象属性
3、指针指向

其中步骤二和步骤三可能出现重排序,此时就可以导致对象还未初始化完成时判断为 true,直接返回异常对象。此时通过 volatile 禁止指令重排序即可。

绝大多数多线程场景需要保证原子性,此时就需要锁的介入

转载地址:http://llxwz.baihongyu.com/

你可能感兴趣的文章
mysql执行计划
查看>>
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>
MySQL执行计划解读
查看>>
mysql执行顺序与索引算法
查看>>
mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
查看>>
mysql批量update操作时出现锁表
查看>>
MYSQL批量UPDATE的两种方式
查看>>
mysql批量修改字段名(列名)
查看>>
MySQL批量插入数据遇到错误1213的解决方法
查看>>
mysql技能梳理
查看>>
MySQL报Got an error reading communication packets错
查看>>
Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
查看>>
MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
查看>>
MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
查看>>
Mysql报错Packet for query is too large问题解决
查看>>
mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
查看>>
Mysql报错:too many connections
查看>>