可重入锁的问题

wyc_ 2014-11-24 03:46:39
如果没有可重入的锁,这段看上去很自然的代码就会产生死锁。因为Widget和LoggingWidget
中的doSomething都是synchronized类型的,都会在处理前试图获得Widget的锁
。倘若内部锁
不是可重入的,super.doSomething的调用者就永远无法得到Widget的锁,因为锁已经被占有。
public class Widget
{
public synchronized void doSomething(){}
}
public class LoggingWidget extends Widget
{
public synchronized void doSomething(){
super.doSomething();
}
}
红色部分怎么理解?调用LoggingWidget的doSomething,这时的锁不是加在子类对象上的吗?
...全文
370 5 打赏 收藏 举报
写回复
5 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
lliiqiang 2014-11-25
锁是对于线程来说的,线程已经有锁了,再要获取锁当然可以继续执行.在执行代码的时候获取了锁,那么线程获取和释放锁就与该代码挂钩,只有当线程获取锁的代码被完全执行完线程才释放锁.
  • 打赏
  • 举报
回复
wyc_ 2014-11-24
引用 3 楼 sum_rain 的回复:
可重入的意思是每个线程可以重复持有多个已持有的锁对象(持有计数自增) 然后可以这样理解,当new出 LoggingWidget对象后,该对象将持有自身的内部锁(一个对象只有一个默认内部锁),然后可以调用dosometing方法,接着调用super.dosomething();由于super只是一个标记符,告诉jvm调用invoke父类的dosomething方法(父类该方法将被继承到子类对象的方法表中),此时并未创建父类对象,所以这个父类方法的锁应该还是LoggingWidget对象的内部锁(唯一),由于可重入,所以持有内部锁后还可以再持有一次而不会陷入死锁。
有道理
  • 打赏
  • 举报
回复
AceShot 2014-11-24
可重入的意思是每个线程可以重复持有多个已持有的锁对象(持有计数自增) 然后可以这样理解,当new出 LoggingWidget对象后,该对象将持有自身的内部锁(一个对象只有一个默认内部锁),然后可以调用dosometing方法,接着调用super.dosomething();由于super只是一个标记符,告诉jvm调用invoke父类的dosomething方法(父类该方法将被继承到子类对象的方法表中),此时并未创建父类对象,所以这个父类方法的锁应该还是LoggingWidget对象的内部锁(唯一),由于可重入,所以持有内部锁后还可以再持有一次而不会陷入死锁。
  • 打赏
  • 举报
回复
rumeng_you 2014-11-24
跟是不是子类没关系的。
  • 打赏
  • 举报
回复
rumeng_you 2014-11-24
同一线程获取的锁是可以被统一线程重入的,然后计数值+1
  • 打赏
  • 举报
回复
发帖
Java SE

6.2w+

社区成员

Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
帖子事件
创建了帖子
2014-11-24 03:46
社区公告
暂无公告