public class Test {
public static int k = 0;
public static Test t1 = new Test("t1");
public static Test t2 = new Test("t2");
public static int i= print("i");
public static int n = 99;
{
print("构造块");
}
static{
print("静态块");
}
public Test(String str) {
System.err.println(++k + ":" + str + " i=" + i + " n=" + n);
++n;
}
public static int print(String str) {
System.err.println(++k + ":" + str + " i=" + i + " n=" + n);
++n;
return ++i;
}
public static void main(String[] args) {
Test test = new Test("init");
System.out.println("=========================================");
Test test1 = new Test("init1");
}
}
经过查看课本和Debug追踪:
1.当第一次创建类时,会给这个类的成员变量中静态变量 给予初始值(int为0,boolean为false)
2. 根据代码 给静态变量赋值
3. 静态块
4.初始化成员变量中的非静态变量
5. 构造块
第二次创建时:
由上述的 4. 开始执行。
特殊情况:
静态变量中 又是创建这个类??
答:经过debug追踪,发现这个类时直接上述的 4. 开始执行。
debug模式下结果:(注意如果直接执行 :是优化过的,结果就不同)
1: j i=0 n=02: 构造块 i=1 n=1
3: t1 i=2 n=2
4: j i=2 n=3
5: 构造块 i=3 n=4
6: t2 i=4 n=5
7: i i=4 n=6
8: 静态块 i=5 n=99
9: j i=6 n=100
10: 构造块 i=7 n=101
11: init i=8 n=102
=========================================
12: j i=8 n=103
13: 构造块 i=9 n=104
14: init1 i=10 n=105