volatile与死循环
在64bit的JVM上以“-server”服务器模式运行java线程类代码时,为了保证在该模式下保障线程运行的效率,线程会一直在私有堆栈中取值,而volatile关键字的作用是强制从公共堆栈中取得变量值,这样就能有效的解决死循环状态。
使用volatile关键字增加了实例变量在多个线程之间的可见性。但volatile关键字最致命的缺点是不支持原子性。
下面将关键字synchronized和volatile进行比较
(1)关键字volatile是线程同步的轻量级实现,所以volatile性能肯定比synchronized要好,并且volatile只能修饰于变量,而synchronized可以修饰方法,以及代码块。随着JDK版本的发布,synchronized关键字在执行效率上得到很大的提升,在开发中使用synchronized关键字的比率还是比较大的。
(2)多线程访问volatile不会发生阻塞,而synchronized会出现阻塞。
(3)volatile能保证数据的可见性,但不保证原子性;而synchronized可以保证原子性,也可以间接保证可见性,因为它会将私有内存和公共内存中的数据做同步。
(4)关键字volatile解决的是变量在多个线程间的可见性;而synchronized解决的是多个线程之间访问资源的同步性。
volatile的使用场景

本文探讨了Java中volatile关键字的作用,它确保了变量在线程间的可见性,但不保证原子性。与synchronized关键字相比,volatile在性能上更优,但在某些场景下仍可能导致非线程安全问题。适合于多线程读取共享变量的场景,但在需要原子操作时需配合锁机制。
订阅专栏 解锁全文
166

被折叠的 条评论
为什么被折叠?



