多态
动态编译:程序的类型只有在执行的时候才能确认,写代码的时候是确定不了的,可拓展性变得更强
即同一方法可以根据发送对象的不同而采用多种不同的行为方式。
一个对象的实际类型是确定的,但可以指向对象的引用的类型有很多
多态存在的条件
- 有继承关系
- 子类重写父类的方法
- 父类引用指向子类对象
注意:多态是方法的多态,属性没有多态性。
instanceof (类型转换:强制转换和自动转换)引用类型
java
package com.oop.demo06;
public class Person {
public void run(){
System.out.println("run");
}
}
/*
多态注意事项:
1.多态是方法的多态,属性没有多态
2.父类和子类,有联系 类型转换异常!ClassCastException
3.存在条件:继承关系,方法都要重写 父类引用指向子类对象! father f1 = new Son();
不能被重写的:
1.static 静态的方法,属于类,它不属于实例
2.final 常量:
3.private 私有的,
*/
java
package com.oop.demo06;
public class Student extends Person{
@Override
public void run() {
System.out.println("son");
}
public void eat(){
System.out.println("eat");
}
}
java
package com.oop;
import com.oop.demo06.Person;
import com.oop.demo06.Student;
import java.util.Scanner;
//一个项目应该只存在一个main方法
public class Application {
public static void main(String[] args) {
//一个对象的实际类型是确定的
//new Student();
//new Person();
//可以指向的引用类型就不确定了:父类的引用指向子类
//Student子类型,能调用的方法都是自己的或者继承父类的
Student s1 = new Student();
//Person父类型,可以指向子类,但是不能调用子类独有的方法
Person s2 = new Student();
Object s3 = new Student();
//那个类型的就执行那个的,两个类型里面都有时执行子类的
s2.run();//子类重写了父类的方法,执行子类的方法
s1.run();
//对象能执行哪些方法,主要看对象左边的类型,和右边关系不大!
//s2.eat();
((Student) s2).eat();//(类型):强制转换、高转低
s1.eat();
}
}
java
son
son
进程已结束,退出代码为 0