博客
关于我
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: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>