关于java中的多态和对实例化对象的一些理解

java面向对象三大特征即为:继承封装多态。而多态需要三大必要条件。分别是:继承、方法重写、父类引用指向子类对象。我们先一个一个来理解。

1、首先是继承和重写。这个很简单。因为多态就是建立在不同的重写之上的。也就是说多态就是在使用着一个方法的不同重写。而重写又是依赖着继承关系。

2、这个父类引用指向子类对象。

首先先上代码示例。

public class Animal {
    public void Shout(){
        System.out.println("叫叫叫");
    }
    public void Hi(){
        System.out.println("打招呼");
    }
}
class Dog extends Animal{
    public void Shout(){
        System.out.println("汪汪汪");
    }
    public void seeHouse(){
        System.out.println("看家");
    }

}class Cat extends Animal{
    public void Shout(){
        System.out.println("喵喵喵");
    }
}

class goose extends Animal{
    public void Shout(){
        System.out.println("嘎嘎嘎");
    }
}

 

 

public class TestPolym {
    public static void main(String[] args) {
        AnimalShout(new Dog());
        AnimalShout(new goose());
    }
    static void AnimalShout(Animal animal){
        animal.Shout();
    }
}

在如上代码中,Animal类是作为dog、cat、goose的父类。而TestPolym则是用于实现多态

先解释下父类引用指向子类对象:在TestPolym类中的AnimalShout方法中,接收着Animal类的对象。这就是父类的引用;

指向子类对象则是看这一行: 

AnimalShout(new Dog());

这里其实可以理解为:

Animal animal = new Dog();

其实这一行打出来基本就可以理解个七七八八。这句话就是定义了一个对象 animal 然后将其实例化成 类型为 Animal 的Dog()。因为Dog、Cat这些是Animal的子类,所以类型 Animal >= Dog、Cat......这些子类。所以首先指向子类是成立的。

其次在 Animal animal = new Dog(); 这个构造器真实的类型为Dog,但是! 编译器在看animal这个对象的时候,只会将他识别为Animal类型而这行代码成立的最重要的原因是:Dog是Animal的一个子类,并且Dog类总是小于等于Animal类。然后我们看一下我们在使用什么方法。这个方法是Shout。是由Animal重写而来。因此在调用由Dog类重写Animal类的方法如此代码中的Shout方法时,此语句成立。 

反之,使用此语句去运行不是由Animal类中的方法重写而来的方法时,此语句会报错。例如用这一行去调用seeHouse时


 编译器会红,并且建议你在Animal中创建这样一个方法,那我们去创建一下。之后就会发现,Animal和Dog两个类中都有Hi方法了,又变成重写了!而且程序也能跑的通了。所以本质上还是Animal类包含(抽象一点的)Dog类。




热门相关:斗神战帝   惊世毒妃:轻狂大小姐   战神   无限杀路   惊世毒妃:轻狂大小姐