继承中的面试题
面试题1:
class Test01_Extends{ public static void main(String[] args){ Zi z = new Zi(); z.show(); } } class Fu{ public int num = 10; public Fu(){ System.out.println("Fu"); } } class Zi extends Fu{ public int num = 20; public Zi(){ //super(); 系统隐藏一个super(); System.out.println("Zi"); } public void show(){ int num = 30; System.out.println(num); //局部变量 System.out.println(this.num); //本类的成员变量 System.out.println(super.num); //父类的成员变量 } }
面试题2:
class Test02_Extends { public static void main(String[] args) { Zi z = new Zi(); } /* 1,jvm调用了main方法,main进栈 2,遇到Zi z = new Zi();会先将Fu.class和Zi.class分别加载进内存,再创建对象,当Fu.class加载进内存 父类的静态代码块会随着Fu.class一起加载,当Zi.class加载进内存,子类的静态代码块会随着Zi.class一起加载 第一个输出,静态代码块Fu,第二个输出静态代码块Zi 3,走Zi类的构造方法,因为java中是分层初始化的,先初始化父类,再初始化子类,所以先走的父类构造,但是在执行 父类构造时,发现父类有构造代码块,构造代码块是优先于构造方法执行的所以 第三个输出构造代码块Fu,第四个输出构造方法Fu 4,Fu类初始化结束,子类初始化,第五个输出的是构造代码块Zi,构造方法Zi */ } class Fu { static { System.out.println("静态代码块Fu"); } { System.out.println("构造代码块Fu"); } public Fu() { System.out.println("构造方法Fu"); } } class Zi extends Fu { static { System.out.println("静态代码块Zi"); } { System.out.println("构造代码块Zi"); } public Zi() { System.out.println("构造方法Zi"); } }