今天看了一道逆天题,反正哥们刚上手是看蒙了
public class Demo {
private static int k = 1;
private static Demo t1 = new Demo("t1");
private static Demo t2 = new Demo("t2");
private static int i = print("i");
private static int n = 99;
{
print("初始化块");
j = 100;
}
private Demo(String str){
System.out.println((k++) + ":" + str + " i=" + i + " n=" + n);
++i;
++n;
}
static {
print("静态块");
n=100;
}
private int j = print("j");
public static int print(String str){
System.out.println((k++) + ":" + str + " i=" + i + " n=" + n);
++n;
return ++i;
}
public static void main(String[] args) {
Demo test = new Demo("test");
}
}
但是从上往下捋一遍,发现不是特别墨迹
就是要从头开始先初始化那几个变量,然后跑静态代码块,然后每次new出来对象都要跑一次动态代码块
初始化完毕之后在跑main
所以结果如下
1:初始化块 i=0 n=0
2:j i=1 n=1
3:t1 i=2 n=2
4:初始化块 i=3 n=3
5:j i=4 n=4
6:t2 i=5 n=5
7:i i=6 n=6
8:静态块 i=7 n=99
9:初始化块 i=8 n=100
10:j i=9 n=101
11:test i=10 n=102
ps:好像是一道阿里的面试题