java面对对象(五)--多态

多态(面向对象特征之一)

        父类类型的变量指向子类创建的对象,使用该变量调用父类中一个被子类重写的方法,则父类中的方法呈现出不同的行为特征,这就是多态。函数本身就具备多态性,某一种事物有不同的具体的体现。

体现:

        父类引用或者接口的引用指向了自己的子类对象。//Animal a = new Cat();

多态的好处:

        A:提高了代码的维护性(继承保证)

        B:提高了代码的扩展性(由多态保证)

多态的弊端:

        不能使用子类的特有功能。

        当父类引用指向子类对象时,虽然提高了扩展性,但是只能访问父类中具备的方法,不可以访问子类中特有的方法。(前期不能使用后期产生的功能,即访问的局限性)

Java实现多态的机制。重载overlond,重写overread实现多态

        重写overread父类与子类之间多态的表现。

        重载overlond一个类中多态的表现。

多态的前提:

    1:必须要有关系,比如继承、或者实现。

    2:通常会有覆盖操作。

多态的出现思想上也做着变化:

        以前是创建对象并指挥对象做事情。有了多态以后,我们可以找到对象的共性类型,直接操作共性类型做事情即可,这样可以指挥一批对象做事情,即通过操作父类或接口实现。

        Java引用变量有两种类型,分别是编译时类型和运行时类型:编译时类型由声明该变量时使用的类型决定;运行时类型由实际赋给该变量的对象。如果编译时类型和运行时类型不一致,就可能出现所谓多态。

       如果编译时类型和运行时类型不一致时未必会出现所谓多态,父类类型的变量指向子类创建的对象,但由于子类中没有重写该变量所调用的父类方法,所以没有出现多态。

上转型对象:

        子类实例化的对象赋值给父类声明变量,则该对象称为上转型对象,这个过程称为对象上转型,对应于数据类型转换中的自动类型转换:

         上转对象不能操作子类新增的成员变量;不能调用子类新增的方法

        上转对象调用父类方法,如果该方法已被子类重写,则表现子类重写后的行为特征,否则表现父类的行为特征。

使用上转型对象调用成员变量,无论该成员变量是否已经被子类覆盖,使用的都是父类中的成员变量:

对象下转型

        可以将上转型对象再强制转换为创建该对象的子类类型的对象,即将上转型对象还原为子类对象,对应于数据类型转换中的强制类型转换。

        还原后的对象又具备了子类所有属性和功能,即可以操作子类中继承或新增的成员变量,可以调用子类中继承或新增的方法。

注意:不可以将父类创建的对象通过强制类型转换赋值给子类声明的变量。

instanceof运算符

        用于判断该运算符前面引用类型变量指向的对象是否是后面类,或者其子类、接口实现类创建的对象。如果是则返回true,否则    返回false:

    new 对象() instanceof 对象父类或对象

引用类型变量 instanceof 类(也可以是接口)

多态在子父类中的成员上的体现的特点:

1,成员变量:在多态中,子父类成员变量同名。

    在编译时期:参考的是引用型变量所属的类中是否有调用的成员。(编译时不产生对象,只检查语法错误

    运行时期:也是参考引用型变量所属的类中是否有调用的成员。

    简单一句话:无论编译和运行,成员变量参考的都是引用变量所属的类中的成员变量。

    再说的更容易记忆一些:成员变量 --- 编译运行都看 = 左边。

2,成员函数。

    编译时期:参考引用型变量所属的类中是否有调用的方法。

    运行时期参考的是对象所属的类中是否有调用的方法。

    为什么是这样的呢?因为在子父类中,对于一模一样的成员函数,有一个特性:覆盖。

    简单一句:成员函数,编译看引用型变量所属的类,运行看对象所属的类。

    更简单:成员函数 --- 编译看 = 左边,运行看 = 右边。

3,静态函数。

    编译时期:参考的是引用型变量所属的类中是否有调用的成员。

    运行时期:也是参考引用型变量所属的类中是否有调用的成员。

    为什么是这样的呢?因为静态方法,其实不所属于对象,而是所属于该方法所在的类。

    调用静态的方法引用是哪个类的引用调用的就是哪个类中的静态方法。

    简单说:静态函数 --- 编译运行都看 = 左边。





猜你喜欢

转载自blog.csdn.net/niudasheng/article/details/80597451