在《Java并发编程实战》中看到,如果synchronized不支持重入,如下代码将会发生死锁。言下之意就是:子类重写父类synchronized方法,这两个方法锁住的对象一致。
public class Widget {
public synchronized void doSomething() {...}
}
public class LoggingWidget extends Widget {
@Override
public synchronized void doSomething() {
System.out.println(...);
super.doSomething();
}
}
但是,为什么一致?子类锁住的是自己的对象,父类锁住的应该是父类的对象啊?怎么两个对象反而一样了?遂做了如下实验:
public class Widget {
public synchronized void doSomething() {
System.out.println("Widget中的this: " + this);
}
}
public class LoggingWidget extends Widget {
@Override
public synchronized void doSomething() {
super.doSomething();
System.out.println("LoggingWidget中的super: " + super.toString());
System.out.println("LoggingWidget中的this: " + this);
}
public static void main(String[] args) {
LoggingWidget loggingWidget = new LoggingWidget();
loggingWidget.doSomething();
}
}
运行结果如下:
很不可思议,super和this居然是同一个引用,而且父类的this也是。所以才会说锁住的是同一个对象。也就是super本身仍然是子类的引用,只不过它可以调用到父类的方法或变量。