volatile是java中个关键字,与Java的内存模型有关
现在程序过程是:数据从主存复制到高速缓存,cpu运算直接冲关村读取并写入,结束后缓存同步到主存
并发编程中的三个概念:
1.原子性:一个事务的完整性
2.可见性:当多个线程访问同一个变量,一个线程修改了改变量,其他线程能够立即看到
3.有序性:程序执行的顺序按照代码的先后顺序执行。
要想并发程序正确运行,必须保证这三个条件有效
volatile关键字保证可见性!
当一个共享变量被volatile修饰时,它会保证修改的值会立即被更新到主存,当有其他线程需要读取时,它会去内存中读取新值。
使用volatile关键字的场景
synchronized关键字可以防止多线程见的并发问题,但是代价是程序的执行效率。而volatile关键字在某些情境下要优于synchronized,但是无法替代synchronized,因为它无法保证操作的原子性,使用volatile必须具备以下2个条件
1.对变量的写操作不依赖于当前值
2.改变量没有包含在具有其他变量的不变式中
以上条件可能有点抽象,讲一下使用的几个场景
1.状态标记量
1
2
3
4
5
6
7
8
9
|
volatile
boolean
flag =
false
;
while
(!flag){
doSomething();
}
public
void
setFlag() {
flag =
true
;
}
|
1
2
3
4
5
6
7
8
9
10
|
volatile
boolean
inited =
false
;
//线程1:
context = loadContext();
inited =
true
;
//线程2:
while
(!inited ){
sleep()
}
doSomethingwithconfig(context);
|
2.double check
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
class
Singleton{
private
volatile
static
Singleton instance =
null
;
private
Singleton() {
}
public
static
Singleton getInstance() {
if
(instance==
null
) {
synchronized
(Singleton.
class
) {
if
(instance==
null
)
instance =
new
Singleton();
}
}
return
instance;
}
}
|