重写和重载是针对方法的,子类的变量可以覆盖父类的变量,但是不能改变父类的变量。
class Animals {
int age = 10;
void enjoy() {
System.out.println("Animals enjoy!");
}
}
class Dogg extends Animals {
int age = 20;
int weight;
void enjoy() {
System.out.println("Dog enjoy!");
}
}
public class TestDuoTai {
public static void main(String[] args) {
Animals a = new Animals();
a.enjoy();
System.out.println(a.age);
Dogg d = new Dogg();
d.enjoy();
System.out.println(d.age);
Animals d1 = new Dogg();
d1.enjoy();
System.out.println(d1.age);
Dogg s = (Dogg)d1;
System.out.println(s.age);
}
}
打印结果:
Animals enjoy!
10
Dog enjoy!
20
Dog enjoy!
10
20
由此可见,父类和子类的变量是同时存在的,即使是同名。
子类中看到的是子类的变量,父类中看到的是父类中的变量。
它们互相隐藏,而同名的方法则是实实在在的覆盖(重写)
如Animals d1 = new Dogg();
d1是Animals类型的引用,只不过指向子类对象new Dogg() 父类引用指向子类对象就是典型的向上造型,向上造型中,引用能调用什么方法就看这个引用是什么类型的(比如d1就只能调用Animals的方法,但是如果此方法被它指向的子类对象进行了重写,那么调用的方法就是子类重写后的形式,这也是多态的表现(动态绑定)) 至于说能调用的属性也一样,看引用的类型(不过如果子类有和父类同名的属性,确实会被覆盖) 总结:引用只能调用其所属类中存在的属性/方法
而访问成员变量就不同了, 因为java中,向上造型呈现的多态性仅仅针对成员函数,成员属性不具有多态性。可以看连接:https://my.oschina.net/u/3701483/blog/1838913
它是Animals时,访问的是父类的成员变量,转型为Dogg的话,访问的就是子类的成员变量了。