java并发编程:关键字

1、关键字volatile(易变的):html

一、保证了多线程操做的可见性;java

二、可是没法保证对变量的任何操做都是原子性的(如自增操做);编程

三、禁止指令重排序,能在必定程度上保证有序性;缓存


禁止指令重排序规则:多线程

一、多个volatile操做之间不会重排序;并发

二、多条volatile操做做为指令段分界点,指令优化重排序只在指令段内部进行,即volatile操做执行时其前面语句都执行完毕,且结果可见;性能

volatile的原理和实现机制:优化

“观察加入volatile关键字和没有加入volatile关键字时所生成的汇编代码发现,加入volatile关键字时,会多出一个lock前缀指令。”——摘自《深刻理解Java虚拟机》spa

lock前缀指令实际上至关于一个内存屏障(也成内存栅栏)线程


多线程操做的可见性:

一、每一个线程都有本身的内存,线程1在运行前会先将stop变量copy一份到本身的内存里(每一个线程都有本身的work memory, 并且共享一个main memory);

二、线程2修改了stop变量后还没来得及写入内存(那么这个时候是放在哪里??参见下一条),线程2转区干别的事情了;

三、使用volatile关键字修饰后的stop变量:

第一:使用volatile关键字会强制将修改的值当即写入主存;

第二:使用volatile关键字的话,当线程2进行修改时,会致使线程1的工做内存中缓存变量stop的缓存行无效(反映到硬件层的话,就是CPU的L1或者L2缓存中对应的缓存行无效);

第三:因为线程1的工做内存中缓存变量stop的缓存行无效,因此线程1再次读取变量stop的值时会去主存读取。


synchronized与volatile:

一、synchronized关键字是防止多个线程同时执行一段代码,那么就会很影响程序执行效率,而volatile关键字在某些状况下性能要优于synchronized;

二、可是要注意volatile关键字是没法替代synchronized关键字的,由于volatile关键字没法保证操做的原子性。


synchronize代码块执行过程:http://www.2cto.com/kf/201504/389055.html

a.线程得到互斥锁(monitor)

b.清空工做内存

c.从主内存拷贝共享变量最新的值到工做内存成为副本

d.执行代码

e.将修改后的副本的值刷新回主内存中

f.线程释放锁



volatile使用场景:

一般来讲,使用volatile必须具有如下2个条件:

1)对变量的写操做不依赖于当前值;

2)该变量没有包含在具备其余变量的不变式中;



refer:

一、Java并发编程:volatile关键字解析(信息量对我这java半吊子略大,须要重读几回,另文章内容正确性也未作判断)

http://www.cnblogs.com/dolphin0520/p/3920373.html

相关文章
相关标签/搜索