代码块的分类
构造代码块
直接定义在中并且前面没有static关键字的代码块,不能定义在成员方法中。每次创建实例化对象的过程中都会调用构造代码块块,且构造代码块的在构造函数之前被调用。
静态代码块
在Java中用static修饰的代码块,静态代码块随着类的加载而执行,且静态代码块一定在主函数main之前执行。如果函数之中有多个静态代码块,则先定义的先执行,后定义的后执行
图片中,我们可以看到在Demo3中的main之后我们定义了一个stati修饰的代码块,程序执行时,static中的输出内容却在主函数里面的类对象创建之前执行。
相关解析
在上面的代码中,我们可以看到,在类Demo3中 ,我们分别定义了
static Demo3 demo1 = new Demo3();
static Demo3 demo2 = new Demo3();
接着是构造代码块
{
System.out.println(“构造代码块”); // 1
}
然后是静态代码块
static {
System.out.println(“静态代码块”); // 2
}
接着是无参构造方法
public Demo3() {
System.out.println(“构造方法”); // 3
}
程序的执行过程是先执行
static Demo3 demo1 = new Demo3();
static Demo3 demo2 = new Demo3();
因为static修饰内容按照先后顺序依次执行,所以先创建两个实例化对象demo1和demo2,在创建这两个对象时又会按照先后顺序调用构造代码块和构造函数,所以输出
构造代码块
构造方法
构造代码块
构造方法
两次创建对象的语句执行之后,顺序执行静态代码块的内容,即输出语句System.out.println(“静态代码块”);
然后顺序执行main函数里面的内容,创建对象demo1,此时调用构造代码块和构造方法,输出
构造代码块
构造方法
如果去掉static会出现什么情况呢
我们发现Eclipse并没有报错,但是在运行过程中出现了报错,报错为StackOverflowError 栈溢出错误
因为去掉static之后,类Demo3中只有一个staic修饰的构造代码块,它优先于main函数执行,所以输出里面内容,即静态代码块 然后开始执行main函数里面的语句,创建对象demo1,并行构造代码块和构造方法,在类Demo3中又出现了对象创建语句
Demo3 demo1 = new Demo3();
Demo3 demo2 = new Demo3();
然后又开始创建类Demo3的实例化对象,进入递归状态,但是这个递归没有递归边界,最终一直不停的自己创建自己的类对象,而类对象是存在栈区的,容量有限,所以出现了栈溢出错误
来源:CSDN
作者:Markyueer
链接:https://blog.csdn.net/Kevinmakai/article/details/104341050