Java中多态(向上转型)机制

1.为什么向上转型?

所谓多态,也即向上转型,就是某个对象的引用视为对其基类的引用,编译对象是基类,运行对象是父类。向上转型的对象由于Java后期绑定的特点,若父类重写了基类中的方法,则它调用的是父类中的方法,其余调用的是基类中的方法。通过多态,我们可以减少代码的冗余,当多个类继承某个基类时,我们希望引用对象调用他们自身的方法,这时只需要写出一条基类的对象引用即可。

2.代码实现

class A{
    void a(){
        System.out.println("A:a()");
        b();
    };
    void b(){
        System.out.println("A:b()");
    }
}
public class Oos extends A{
    void b(){
        System.out.println("B:b()");
    }
    public static void main(String args[]){
        A test=new Oos();
        test.a();
    }
}

这个例子中,test即为向上转型的对象,它调用a()方法时,因为父类中没有a()方法,所以调用的是基类的a()方法,在基类a()方法中,又调用了本身的b()方法,而它在父类Oos中有重写过,因此调用的是父类中的b()方法。输出如下所示:



3.缺陷

(1)只有非private方法才能覆盖,因为private默认为final类型,当基类中的方法为private时,父类中的非private同名方法视为全新的方法,后期不会绑定它父类中的方法。代码如下;

class A{
    void a(){
        System.out.println("A:a()");
        b();
    }
    private void b(){
        System.out.println("A:b()");
    }
}

public class Oos extends A{
    public void b(){
        System.out.println("B:b()");
    }
    public static void main(String args[]){
        A test=new Oos();
        test.a();
    }
}

结果为:


(2)对于基类和父类的数据成员,向上转型对象不会覆盖数据成员,代码如下:

class A{
    int i=0;
    void a(){
        System.out.println("A:a() i="+i);
        b();
    };
    void b(){
        System.out.println("A:b()");
    }
}

public class Oos extends A{
    int i=1;
    void b(){
        System.out.println("B:b() i="+i);
    }
    public static void main(String args[]){
        A test=new Oos();
        test.a();
    }
}

结果为:


可以看到B中覆盖的方法中i的值还是自己类中的值,不会覆盖数据成员。

(3)静态方法方法不具有多态性,因为静态方法在编译前就已被初始化,不具有后期绑定的特点。代码省略。

猜你喜欢

转载自blog.csdn.net/kuishao1314aa/article/details/80842813
今日推荐