问题:面试问道的一个题当时有点蒙圈了,看懂这段代码就理解了!
class Fu {
static {
System.out.println("父亲的static方法");
}
Fu() {
System.out.println("父亲的构造函数");
}
}
class Zi extends Fu {
static {
System.out.println("--->子类的static方法");
}
Zi() {
System.out.println("--->子类的构造函数");
}
}
//第一段测试代码:没有加句zi=new Zi();语句
public class MyLoginShiro {
public static void main(String[] args)
{
Zi zi=new Zi();//这一句Zi zi就是类加载了,但是子类的属于父类,会去加载Fu类,然后又会加载Zi类这个类,
//这样的话就会执行Fu和Zi中的static方法了,然后new Zi()的话就默认就会调用父类的构造方法,所以会先
//执行fu类的构造方法,然后执行Zi的构造方法
//zi=new Zi();
}
}
/*
第一种输入结果:
父亲的static方法
--->子类的static方法
父亲的构造函数
--->子类的构造函数
*/
//第二段测试代码:就是加了一句zi=new Zi();语句
public class MyLoginShiro {
public static void main(String[] args) {
Zi zi = new Zi();
// 打开
System.out.println("----------------");
zi = new Zi();// 因为这一句已经是一个对象存在
// 的形式,没有去加载类,所以就没有调用static方法
}
}
/*
父亲的static方法
--->子类的static方法
父亲的构造函数
--->子类的构造函数
----------------
父亲的构造函数
--->子类的构造函数
*/
/*总结:Zi zi = new Zi(); 这句中加载了Fu,Zi两个类,所以会先行Fu,Zi中的两个static方法
然后因为new Zi()调用了Zi类空构造函数,这里存在一个特性就是在空Zi类构造中隐藏super()方法调用
了Fu类的构造方法,所以会执行Fu,Zi的构造方法,但是这句zi=new Zi();就不一样了,因为它没有重新
定义变量,而是引用了上面定义好了的类,上句(Zi zi=new Zi())代码已经加载了类了,所以不会再去调用
静态方法了,所以就只调用Fu,Zi类的构造方法了!*/