Java volatile:修订间差异

来自WHY42
imported>Soleverlee
Riguz留言 | 贡献
无编辑摘要
第1行: 第1行:
线程变量存在于公共堆栈和私有堆栈中,当JVM以-server模式启动时,为了提高线程运行时效率,线程一直在私有堆栈中取值。设置成volatile后,则会强制从公共堆栈中取值。使用volatile关键字增加了实例变量在多个线程之间的可见性。
线程变量存在于公共堆栈和私有堆栈中,当JVM以-server模式启动时,为了提高线程运行时效率,线程一直在私有堆栈中取值。设置成<span class="article-label">volatile</span>后,则会强制从公共堆栈中取值。使用volatile关键字增加了实例变量在多个线程之间的可见性。


volatile不能保证原子性。
volatile不能保证原子性。
第8行: 第8行:


=volatile和synchronized比较=
=volatile和synchronized比较=
#volatile是线程同步的轻量级实现,性能稍优于synchronized,volatile只能修饰变量。
 
#volatile是线程同步的轻量级实现,性能稍优于<span class="article-label">synchronized</span>,volatile只能修饰变量。
#多线程范文volatile不会导致阻塞,但synchronized会出现阻塞
#多线程范文volatile不会导致阻塞,但synchronized会出现阻塞
#volatile能保证数据的可见性,但不能保证原子性;而synchronized可以保证原子性,间接保证了可见性
#volatile能保证数据的可见性,但不能保证原子性;而synchronized可以保证原子性,间接保证了可见性
第15行: 第16行:


[[Image:Java_MutiThread_Mem.png|600px]]
[[Image:Java_MutiThread_Mem.png|600px]]
[[Category:Programe]]
 
[[Category:Concurrency]]

2021年4月28日 (三) 14:28的版本

线程变量存在于公共堆栈和私有堆栈中,当JVM以-server模式启动时,为了提高线程运行时效率,线程一直在私有堆栈中取值。设置成后,则会强制从公共堆栈中取值。使用volatile关键字增加了实例变量在多个线程之间的可见性。

volatile不能保证原子性。

volatile和synchronized比较

  1. volatile是线程同步的轻量级实现,性能稍优于,volatile只能修饰变量。
  2. 多线程范文volatile不会导致阻塞,但synchronized会出现阻塞
  3. volatile能保证数据的可见性,但不能保证原子性;而synchronized可以保证原子性,间接保证了可见性
  4. volatile解决变量在多个线程之间的可见性,而synchronized解决的是多个线程之间访问资源的同步性。
  5. synchronized可以保证互斥性和可见性,保证进入同步方法或者代码块的每个线程都看到由同一个锁保护之前所有的修改效果。