饿,好吧,我说错了,来,咱再来种解释…………
现在的情况是子类的void f(long x)根本没有覆盖父类的void f(double x) (看来是真的要形参完全相同才能覆盖)
那么在调用t.g(20L)的时候,g函数里面再调用f(x),那么现在是去找f(x),要注意,是在父类里面找(不会到子类去找的,因为g函数是父类的。)找的时候首先找void f(long x),没找到,那么跟据数据类型的自动转换规则(int->long->float->double),long转成float,但也没有void f(float x),那么再转换成double,正好有void f(double x),成交……,此规则可按如下示例验证。public static void test(float a)
{
System.out.println("float:" + a);
}
public static void test(double a)
{
System.out.println("double:" + a);
}
public static void main(String[] args)
{
test(1);
}
另外,至于我刚说的在父类的g()函数里,只会找父类的函数,有两点:
1你可以在子类增加一个,然后调用这个函数,它就会去调子类的void f(long)了。
void tt(long x)
{
f(x);
}
2.你会说,第一个例子"int in S: ",不是调了子类的void f(int)了吗,而没有调父类的。如果你这么理解就没问题了:“调用的仍然是父类的void f(int),但是它已经被覆盖了,被重写了,被重写成跟子类的那个一样的”
综上,来个最终示例,见图。子类有f(float),但父类的g函数表示找不到它,另外float无法转换成int,所以父类的f(int)也表示无能为力,找不到就是找不到- -