我对java中的方法调度感到困惑。为什么第一种方法“a.m1(b)”调用A类?
调用变量是a。它的运行时类型是B,不是吗?
class A {
public void m1(A a){
System.out.println("A-m1");
}
public void m1(){
System.out.println("A-m1");
}
}
class B extends A {
public void m1( B b){
System.out.println("B-m1");
}
public void m1(){
System.out.println("B-m1");
}
}
public class HelloWorld {
public static void main(String[] args) {
B b = new B();
A a = new B();
a.m1(b);//prints A-m1
a.m1();//prints B-m1
}
}
答案 0 :(得分:7)
重载解析基于编译时类型完成。类型A
的变量仅公开方法m1()
和m1(A)
。因为传入参数,所以调用了m1(A)
;或者更确切地说,适当的覆盖。除m1(B)
不 {{1>}的覆盖以外。 (在我的头顶,我不知道覆盖是否可以扩大参数签名,但他们当然不能缩小它们。)