博客
关于我
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慢查询分析和性能优化的方法和技巧
查看>>
MySQL慢查询日志总结
查看>>
Mysql慢查询日志,查询截取分析
查看>>
MySQL慢查询问题排查
查看>>
mysql截取sql语句
查看>>
mysql截取身份证号前几位_EXCEL中怎样截取身份证号前六位数字
查看>>
mysql手工注入
查看>>
MySQL执行SQL文件出现【Unknown collation ‘utf8mb4_0900_ai_ci‘】的解决方案
查看>>
Mysql执行update by id的过程
查看>>
mysql执行计划
查看>>
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>
MySQL执行计划解读
查看>>
mysql执行顺序与索引算法
查看>>
mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
查看>>
mysql批量update操作时出现锁表
查看>>
MYSQL批量UPDATE的两种方式
查看>>