可重入锁的问题

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,这时的锁不是加在子类对象上的吗?
...全文
579 5 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
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

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧