在调用成员变量以及静态方法时,“编译看左边,运行看左边”,即程序编译时创建了一个Animal类型的对象,并且使用new Cat()对于这个Animal对象赋值,但最终得到的还是一个Animal类的对象,只需要看“=”左边的Animal animal即可。
但是要调用非静态方法时,由于Animal类的对象是用Cat()来实例化的,这个非静态方法在运行时会被重写,从而输出子类中方法重写后的结果。这就是“编译看左边,运行看右边”。
代码运行结果如下:
package case01;
class Animal {
static String name = "animal";
int num = 1;
public static void sleep() {
System.out.println("animal sleep");
}
public void run() {
System.out.println("animal run");
}
}
class Cat extends Animal{
static String name = "cat";
int num = 2;
public static void sleep() {
System.out.println("cat sleep");
}
public void run() {
System.out.println("cat run");
}
}
//对于多态中成员访问的特点:
//成员变量:编译和运行都看左边
//成员方法:编译看左,运行看右
public class Example02 {
public static void main(String[] args) {
Cat cat = new Cat();
Animal animal = cat;
System.out.println(animal.num);
System.out.println(animal.name);
animal.run();
Animal.sleep();
System.out.println(cat.num);
System.out.println(cat.name);
cat.run();
Cat.sleep();
}
}