public class Father { static { System.out.println("Father静态块"); } { System.out.println("Father构造块"); } public Father() { System.out.println("Father构造函数"); } void func1() { System.out.println("Father方法 1"); } public static void main(String[] args) { Father father = new Son(); father.func1(); ((Son) father).func2(); // father.func2(); } } class Son extends Father { static{ System.out.println("Son静态块"); } { System.out.println("Son构造块"); } public Son() { System.out.println("Son构造函数"); } @Override void func1() { System.out.println("Son方法 1"); } void func2() { System.out.println("Son方法 2"); } }
结果:
父类静态块 -> 子类静态块 -> 父类构造块 -> 父类构造函数 -> 子类构造块 -> 子类构造函数
在main方法中:
①father对象指向的是new 出来的Son对象,且Son对象继承Father对象并且@override 重写(覆盖)了父类的func1() 方法,即这样的话,子类对象赋给父类对象,父类对象调用父类中被子类重写的方法时,实际是调用了子类中已经重写过的方法,即:
Father f = new Son(); f.func1();
Son s = new Son(); s.func1();
两者都是一样的,都是指向new 出来的Son 对象。
②因为father对象指向new 出来的Son 对象,所以可以将father对象强制转换成 Son对象,这样就可以调用 Son对象的func2()方法,因为两者在内存上就是一样的存在。
③错误,father对象不存在func2() 方法,只能强制转换成 Son对象,即可调用。