多态包含:
1.运行时多态
2.编译时多态
编译时多态
方法重载:这里不再多说,上一篇有说明方法重载
方法重载链接
运行时多态
方法重写
多态存在的三个必要条件:
1.继承
2.重写
3.父类指向子类引用
上代码:
package Test_06;
public class Animal1 {
public String name="动物";
public void say(){
System.out.println("我是动物");
}
}
class Cat extends Animal1{
public String name="cat";
@Override
public void say() {
System.out.println("我是cat");
}
}
class test8{
public static void main(String[] args) {
Animal1 animal1=new Cat();
System.out.println(animal1.name);
animal1.say();
}
}
结果如下:
动物
我是cat
在test8中
Animal1 animal1=new Cat();
这个就是典型的多态的例子
下面再来说说,为什么
System.out.println(animal1.name);
输出是动物,不是cat;
java引用变量分为编译时类型和运行时类型
下面来说说甚麽是编译时类型和运行时类型;
编译时期可以理解为jvm还没有给变量分配内存空间,此时只有变量的声明
而运行时期可以理解为jvm给变量在堆中分配内存空间;
引用一篇博客的话就是:
Person p=new Women()(Women类继承自Person类)那么,假如p的属性修饰符为public 访问属性时得到的是Person类的属性还是Women类的属性,方法调用又是哪个类?答案:会得到Person类的属性,调用Women类的方法。为什么会这样呢?这里就需要知道什么是编译时类型和运行时类型,Java程序状态会分为编译和运行这两种状态,编译时,JVM会在栈中静态创建基本数据变量,和引用数据变量的引用,回到刚刚那句代码,显然,p这个引用就是在编译时创建的,那么,p的编译时类型就是Person了,当运行这句java代码时,JVM在堆中为p新建一块内存,对应new Women()这句代码,所以p的运行时类型就是Women
如果子类想用自己的属性,必须使用子类的对象调用;
最后送大家一句口诀就是编译看左边,运行看右边;