Java引用变量有两个类型,一个是编译时类型,一个是运行时类型。
如果编译时类型和运行时类型不一致,就可能出现所谓的多态。
package chap5_7;
class BaseClass
{
public int book=6;
public void base()
{
System.out.println("父类的普通方法");
}
public void test()
{
System.out.println("父类的被覆盖方法");
}
}
public class SubClass extends BaseClass {
public String book="轻量级Java EE";
public void test()
{
System.out.println("子类的覆盖父类的方法");
}
public void sub()
{
System.out.println("子类的普通方法");
}
public static void main(String[] args) {
// TODO Auto-generated method stub
BaseClass bc=new BaseClass();
System.out.println(bc.book);
bc.base();
bc.test();
SubClass sc=new SubClass();
System.out.println(sc.book);
sc.base();
sc.test();
BaseClass ploymophicBc=new SubClass();
System.out.println(ploymophicBc.book);
ploymophicBc.base();
// ploymophicBc.sub();
}
}
运行结果
6
父类的普通方法
父类的被覆盖方法
轻量级Java EE
父类的普通方法
子类的覆盖父类的方法
6
父类的普通方法
ploymophicBc调用引用变量的test()方法,实际执行的是SubClass类中覆盖后的test()方法,这就可能出现多态了。
多态:相同类型的变量、调用同一个方法时呈现出多种不同的行为特征。
引用变量在编译阶段只能调用其编译时类型所具有的方法,但运行时则执行它运行时类型所具有的方法。因此,编写Java代码时,引用变量只能调用声明该变量时所用类里包含的方法。例如,通过Object p=new Person()代码定义一个变量p,则这个p只能调用Object类的方法,而不能调用Person类里定义的方法。
通过引用变量来访问其包含的实例变量时,系统总是试图访问它编译时类型所定义的成员变量,而不是它运行时类型所定义的成员变量。