Synchronized 对象锁/类锁差异概要总结


前言这,这里主要对Synchronized不同使用方式的一个概要总结,具体实践并未粘贴,大家自行实践.

1.对象锁

包含两个种类:

synchronized(this)
synchronized修饰非static方法

这两类的锁是实例对象,不同的多个对象之间互相不干扰,是独立的.同一个实例对象,只有一个对象锁:

场景:有一个类A,且 A1,A2都是A的实例化对象,有两个线程thread1 和thread2
A:{
   public synchronized  a(){..}
   public synchronized  b(){..}
}
1) thread1 和 thread2用一时间分别调用A1的方法a和b( thread1调用a, thread2调用吧)。如果thread1 先获得锁,为释放的情况下,thread2是无法访问b方法的
2) thread1调用A1的a, thread2调用后A2的方法b或者a。thread1和thread2之间不会相互影响,他们依赖的不是相同的锁。

2.类锁

包含两个种类:

synchronized 修饰static方法
synchronized(***.class)

这两类修饰方式是类对象.实例对象有可以有多个,但实例class只有一个.也就不同对象之前是共享的唯一的一个锁:

场景:如上个场景一样。有一个类A,且 A1,A2都是A的实例化对象,有两个线程thread1 和thread2。
A:{
   public synchronized  a(){..}
   public synchronized  b(){..}
}
1) 两个线程调用同一个锁,这种情况如上,是相似的需等待。
2)不同点在这里,即使两个线程调用不同的实例对象,也要等待相同的锁。如  thread1调用A1的a, thread2调用后A2的方法b或者a,如果thread1先获得锁未释放,则另一个线程需要等待锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值