一个对象可以被用作它自身的类型或者是它的基类类型。当用作它的基类类型时叫做upcasting,如下所示
BaseClass ref = new DerivedClass() //upcasting
当执行ref.method 时,程序会先到DerivedClass中去寻找method,当找到时就执行,找不到时就会到BaseClass
中找是否有method(该method必须是对DerivedClass是可见的),如果有则执行。
BaseClass
中的private方法只能被基类中的方法调用,对DerivedClass是不可见的。因此DerivedClass无法override BaseClass中的private方法,也不能通过
upcasting来调用基类中的private方法。
基于上述的原因,下面的例子是无法编译通过的:
public class test {public static void main(String[] args){
test1 t = new test2();
t.f();
}
}class test1{
private void f(){
System.out.println("test1 private f()");
}
}class test2 extends test1{
public void f(){
System.out.println("test1 public f()");
}
}
然而书中的一个例子却给出了意外的结果:
public class PrivateOverride{
private void f(){
System.out.println("PrivateOverride private f()");
}
public static void main(String[] args){
PrivateOverride po = new Derived();
po.f();
}
}class Derived extends PrivateOverride{
public void f(){
System.out.println("Derived public f()");
}
}
执行结果为:
PrivateOverride private f()
看起来违背了开始描述的理论,但是经过分析过后发现,上例中的upcasting 和 方法的调用是在基类中进行的,在基类中可以访问基类的私有方法。
还有一点需要说明,派生类overrid基类中的方法时,其权限只能大于等于基类中该方法的权限
也就是说,当基类中方法的权限为protected时,派生类重写该方法时,权限必须为protected 或者是 public.