《Java并发编程实践》一书-2.3.2重入机制树上问题
问题描述:
public class Widget {
public synchronized void doSomething(){
//...
}
}
class LoggingWidget extends Widget{
public synchronized void doSomething(){
System.out.println(toString()+":calling doSomething");
super.doSomething();
}
}
代码见上,对应对Java并发编程实践P21,书本上说,在构造子类对象后,调用doSomething方法时,每个doSomething方法在执行前都会获取Widget上的锁;我的问题是:从始至终不是只创建了子类LoggingWidget对象,锁不是应该属于子类对象LoggingWidget的?
答
创建父类Widget的时候要先初始化它的父类Object
创建子类LoggingWidget得先初始化它的父类Widget。虽然LoggingWidget代码里面没有构造方法,但是已经帮你做了,调用父类默认构造方法。
至于说锁不应该属于子类对象LoggingWidget,这个没错
class CFater {
public synchronized void doSomething() {
System.out.println("fahter do something, this is " + this);
}
}
class CSon extends CFater {
public synchronized void doSomething() {
System.out.println("son do something, this is " + this);
super.doSomething();
}
}
public class Test {
public static void main(String args[]) {
CSon son = new CSon();
son.doSomething();
}
}
打印一下this,你就知道是谁了。 synchronized锁方法的时候,锁的是当前对象--this。这两的this是一样的。
son do something, this is CSon@659e0bfd
fahter do something, this is CSon@659e0bfd
其实这里子类的doSomething覆盖了父类的doSomething了,父子类的锁也能重入的。