class A{
int i=10;
public void show(){
System.out.println(i);
}
}
class B extends A{
int i= 100;
public void show (){
System.out.println(i);
}
}
public class Test {
public static void main(String []args){
A a= new B();//A的引用指向B的对象。
a.show();/*结果是100,结果是可预料的,不管引用是什么,表现将是子类的样子。比如我需要一个动物,结果得到了一只公鸡
,那么我让这只动物叫,就会得到公鸡的叫声。*/
//如果我们直接访问成员变量,看看得到什么。
System.out.println(a.i);
/*结果是10,我们发现如果方法被重写了,他是成员变量也重复定义了,父类的引用指向
子类的对象,调用的方法将是子类的,而成员变量的值将是父类的。这是java的编译机制造成的。方法时在运行的时候取值,
所以方法时动态绑定的,而成员变量的初值是编译的时候就绑定的。这种结果挺让人郁闷的,为了避免这类问题,java程序员通常会使用
方法,而不是直接使用成员变量。*/
}
}
这类型的属于转型问题,分为向上或向下转型。
向上转型:Person p= new Man();//不需要强制类型转化。
向下转型:Man man=(Man) new Person();//必须强制类型转化。
总的来说一句话,“编译看左边,运行看右边 ”也就是编译的时候,会看左边引用类型是否能正确编译通过,运行的时候是调用右边的对象的方法。