我们这样假设下,super(超类)、this(当前类对象)、show(方法)、object(对象),方法调用优先顺序: ①this.show(object)>②super.show(object)> ③this.show((super)object)>④super.show((super)object)
先看以下代码
1
2
3
4
5
6
7
8
9
|
class ParentCls { public String show(ChildA obj){ return "Parent and ChildA" ; } public String show(ParentCls obj) { return "Parent" ; } } |
然后写一个子类ChildA ,继承ParentCls :
1
2
3
4
5
6
7
8
|
class ChildA extends ParentCls{ public String show(ChildA obj) { return "ChildA" ; }; public String show(ParentCls obj) { return "ChildA and Parent" ; }; } |
写一个子类ChildB,继承ChildA :
class ChildB extends ChildA{
}
测试下
1
2
3
4
5
6
7
8
9
10
|
public static void main(String[] args) { ParentCls p1 = new ParentCls(); ParentCls p2 = new ChildA(); ChildA a = new ChildA(); ChildB b = new ChildB(); System.out.println(p1.show(a)); System.out.println(b.show(a)); System.out.println(a.show(b)); System.out.println(p2.show(a)); } |
输出
1
2
3
4
|
Parent and ChildA ChildA ChildA ChildA |
第一个输出,p1是ParentCls的实例,且类ParentCls中有show(ChildA obj)方法,直接执行该方法, ①有效;
第二个输出,b是ChildB 的实例,类ChildB 中没有show(ChildA obj)方法,①无效,再从ChildB 的父类ChildA查找,ChildA中刚好有show(ChildA obj)方法,②有效;
第三个输出,a是ChildA的实例,b是ChildB的实例,类ChildA中没有show(ChildB obj)方法,①无效,再从ChildA的父类ParentCls入手,ParentCls中也没有show(ChildB obj)方法,②无效,从ChildB的父类入手,(super)ChildB 即是ChildA,所以a.show(b)=>a.show(a),ChildA中刚好有show(ChildA obj)方法,③有效;
④就不作演示,根据①②③很容易得出结论;
第四个输出,体现Java多态性,符合①,但是p2是引用类ChildA的一个对象 ,ChildA 重写覆盖了ParentCls的show()方法,所以执行ChildA 的show()方法;
补充知识:Java中关于静态块,初始化快,构造函数的执行顺序
代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
public class ParentDemo { static { System.out.println( "this is ParentDemo static" ); } { System.out.println( "this is ParentDemo code block" ); } public ParentDemo() { System.out.println( "this is ParentDemo constructor" ); } } public class SonDemo extends ParentDemo{ static { System.out.println( "this is SonDemo static" ); } { System.out.println( "this is SonDemo code block" ); } public SonDemo() { System.out.println( "this is SonDemo constructor" ); } } public class TestMain { public static void main(String[] args){ new SonDemo(); } } |
输出结果:
1
2
3
4
5
6
|
this is ParentDemo static this is SonDemo static this is ParentDemo code block this is ParentDemo constructor this is SonDemo code block this is SonDemo constructor |
由上可见,Java中 静态块中的代码在类加载时执行,子类继承父类。会按照继承的顺序先执行静态代码块。当实例化对象的时候,同理会按照继承的顺序依次执行如下代码:
代码块,构造函数,当父类的执行完以后,再执行子类。
以上这篇浅谈Java方法调用的优先级问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/u014063265/article/details/68063497