13.Java多线程之Synchronized和Volatile的比较

本文深入探讨了Java多线程中的内存可见性和原子性,对比了Synchronized和Volatile的特性。Synchronized保证了可见性和原子性,而Volatile仅保证可见性。Synchronized可能导致线程阻塞,而Volatile则不会。在复杂同步场景下,ReentrantLock(Lock的一种实现)提供了更多的控制选项,如响应中断、条件控制和公平锁。
摘要由CSDN通过智能技术生成

Java多线程之内存可见性和原子性:SynchronizedVolatile的比较

      在说明Java多线程内存可见性之前,先来简单了解一下Java内存模型。

     1Java所有变量都存储在主内存中
     
2)每个线程都有自己独立的工作内存,里面保存该线程的使用到的变量副本(该副本就是主内存中该变量的一份拷贝)

   1)线程对共享变量的所有操作都必须在自己的工作内存中进行,不能直接在主内存中读写
   
2)不同线程之间无法直接访问其他线程工作内存中的变量,线程间变量值的传递需要通过主内存来完成。
线程1对共享变量的修改,要想被线程2及时看到,必须经过如下2个过程:
   
1)把工作内存1中更新过的共享变量刷新到主内存中
   
2)将主内存中最新的共享变量的值更新到工作内存2

可见性与原子性

   可见性:一个线程对共享变量的修改,更够及时的被其他线程看到
   
原子性:即不可再分了,不能分为多步操作。比如赋值或者return
比如"a = 1;" "returna;"这样的操作都具有原子性。类似"a +=b"这样的操作不具有原子性,在某些JVM"a +=b"可能要经过这样三个步骤:
 取出ab
 计算a+b
 将计算结果写入内存



(1)Synchronized:保证可见性和原子性
   Synchronized能够实现原子性和可见性;在Java内存模型中,synchronized规定,线程在加锁先清空工作内存在主内存中拷贝最新变量的副本到工作内存执行完代码将更改后的共享变量的值刷新到主内存中释放互斥锁。


(2)Volatile
:保证可见性,但不保证操作的原子性
   Volatile实现内存可见性是通过storeload指令完成的;也就是对volatile变量执行写操作时,会在写操作后加入一条store指令,即强迫线程将最新的值刷新到主内存中;而在读操作时,会加入一条load指令,即强迫从主内存中读入变量的值。但volatile不保证volatile变量的原子性,例如:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值