在调试的过程中,经常可以看到 <init>
一个初始化函数
它是这个样子的
刚开始没有注意,后来发现其实 其实就是这个类的构造函数
那么又是什么呢? 其实就这这个类的静态代码块的集合
举个例子吧,下面是一个Demo类。如果里面没有静态代码块,就和下面一样,只有简单的静态函数,那么我们可以看一下
public class Demo {
public Demo () {
System.out.println("构造函数");
}
public static void main(String[] args) {
Demo demo = new Demo();
}
}
加个断点就可到一个函数,指向了构造函数
当我们加上静态函数块,再来看
public class Demo {
static {
System.out.println("静态代码块");
}
public Demo () {
System.out.println("构造函数");
}
public static void main(String[] args) {
System.out.println("开始执行主函数啦!");
Demo demo = new Demo();
}
}
这里的代码首先进入的不是main函数,而是 <clinit>
函数。
我们都知道静态代码块只执行一次,并且是最先执行。可是有没有想过为什么呢?
其实这是由jvm规定的,在加载类的时候,jvm执行顺序是 加载
->验证
->解析
->初始化
,在 初始化
的过程中,编译器自动收集类中所有的变量赋值动作和静态语句块中的语句合并而成的<clinit> 类构造方法
。 当时这个不是必须的,因为有些类没有静态构造方法。而初始化的过程只是在加载类的时候执行的,所以只会执行一次,并且是最开始执行。这也就解释了为什么静态代码块最先执行。
以下是输出结果
静态代码块
开始执行主函数啦!
构造函数