多线程之子类重写父类synchronized方法,父类方法锁住的对象是谁?


在《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本身仍然是子类的引用,只不过它可以调用到父类的方法或变量。

https://my.oschina.net/u/3149614/blog/3032984


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM