ObjectLock & ClassLock

对象锁
当一个对象中有synchronized method或synchronized block的时候
调用此对象的同步方法或进入其同步区域时,就必须先获得对象锁
如果此对象的对象锁已被其他调用者占用,则需要等待此锁被释放

同步静态方法/静态变量互斥体
由于一个class不论被实例化多少次,其中的静态方法和静态变量在内存中都只由一份
所以,一旦一个静态的方法被申明为synchronized
此类所有的实例化对象在调用此方法,共用同一把锁,我们称之为类锁
一旦一个静态变量被作为synchronized block的mutex
进入此同步区域时,都要先获得此静态变量的对象锁

类锁
由上述同步静态方法引申出一个概念,那就是类锁
其实系统中并不存在什么类锁
当一个同步静态方法被调用时,系统获取的其实就是代表该类的类对象的对象锁

在程序中获取类锁
可以尝试用以下方式获取类锁
synchronized (xxx.class) {...}
synchronized (Class.forName("xxx")) {...}

同时获取2类锁
同时获取类锁和对象锁是允许的,并不会产生任何问题
但使用类锁时一定要注意,一旦产生类锁的嵌套获取的话,就会产生死锁
因为每个class在内存中都只能生成一个Class实例对象
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值