博客
关于我
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性能优化(1):SQL的执行过程
查看>>
Mysql性能优化(2):数据库索引
查看>>
Mysql性能优化(3):分析执行计划
查看>>
Mysql性能优化(4):优化的注意事项
查看>>
Mysql性能优化(6):读写分离
查看>>
MySQL性能测试及调优中的死锁处理方法
查看>>
mysql性能测试工具选择 mysql软件测试
查看>>
mysql恢复root密码
查看>>
Mysql悲观锁
查看>>
MySQL慢查询-开启慢查询
查看>>
MySQL慢查询分析和性能优化的方法和技巧
查看>>
MySQL慢查询日志总结
查看>>
Mysql慢查询日志,查询截取分析
查看>>
MySQL慢查询问题排查
查看>>
mysql截取sql语句
查看>>
mysql截取身份证号前几位_EXCEL中怎样截取身份证号前六位数字
查看>>
mysql手工注入
查看>>
MySQL执行SQL文件出现【Unknown collation ‘utf8mb4_0900_ai_ci‘】的解决方案
查看>>
Mysql执行update by id的过程
查看>>
mysql执行计划
查看>>