package com.heima.eclipse;
import java.awt.print.Printable;
import java.util.Scanner;
import javax.security.auth.x500.X500Principal;
public class HelloWorld1 {
public static void main(String[] args){
Zi z = new 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() {
//super();
System.out.println("构造方法Zi");
}
}
输出为:
静态代码块Fu
静态代码块Zi
构造代码块Fu
构造方法Fu
构造代码块Zi
构造方法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,相当于子类的构造方法的第一行有一句super(),去调用父类的构造方法。
4.父类初始化结束后,接着是子类的初始化,所以第五个输出的是构造代码块Zi,第六个输出构造方法Zi.