博客
关于我
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架构与SQL的执行流程_1
查看>>
MySQL架构与SQL的执行流程_2
查看>>
MySQL架构介绍
查看>>
MySQL架构优化
查看>>
MySQL查看数据库相关信息
查看>>
MySQL查看表结构和表中数据
查看>>
MySQL查询优化:LIMIT 1避免全表扫描
查看>>
MySQL查询优化之索引
查看>>
mysql查询储存过程,函数,触发过程
查看>>
mysql查询总成绩的前3名学生信息
查看>>
MySQL查询报错ERROR:No query specified
查看>>
MySQL查询数据库所有表名及其注释
查看>>
MySQL查询数据表中数据记录(包括多表查询)
查看>>
mysql查询语句能否让一个字段不显示出来_天天写order by,你知道Mysql底层执行原理吗?
查看>>
MySQL死锁套路:一次诡异的批量插入死锁问题分析
查看>>
Mysql死锁问题Deadlock found when trying to get lock;try restarting transaction
查看>>
mysql每个数据库的最大连接数_MySQL数据库最大连接数
查看>>
Mysql流程控制结构,if函数、case结构、if结构、循环结构
查看>>
mysql添加用户
查看>>
MySQL添加用户、删除用户与授权
查看>>