重写和重载是针对方法的,子类的变量能够覆盖父类的变量,可是不能改变父类的变量。java
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.net
因而可知,父类和子类的变量是同时存在的,即便是同名。
子类中看到的是子类的变量,父类中看到的是父类中的变量。
它们互相隐藏,而同名的方法则是实实在在的覆盖(重写)code
如Animals d1 = new Dogg();
d1是Animals类型的引用,只不过指向子类对象new Dogg() 父类引用指向子类对象就是典型的向上造型,向上造型中,引用能调用什么方法就看这个引用是什么类型的(好比d1就只能调用Animals的方法,可是若是此方法被它指向的子类对象进行了重写,那么调用的方法就是子类重写后的形式,这也是多态的表现(动态绑定)) 至于说能调用的属性也同样,看引用的类型(不过若是子类有和父类同名的属性,确实会被覆盖) 总结:引用只能调用其所属类中存在的属性/方法
而访问成员变量就不一样了, 由于java中,向上造型呈现的多态性仅仅针对成员函数,成员属性不具备多态性。能够看链接:https://my.oschina.net/u/3701483/blog/1838913
它是Animals时,访问的是父类的成员变量,转型为Dogg的话,访问的就是子类的成员变量了。对象