1静态常量,2静态方法,3静态代码块,4类的构造函数,5一般常量,6一般方法,7一般代码块
这些在编译中的顺序是怎样的,一下将要用代码来解释一下:
public class A {
static int a = 2; //定义静态变量
private static void doTell(){ //静态方法
System.out.println("静态方法"+a);
}
static{ //静态代码块
System.out.println("静态代码块"+a);
}
A(){ //构造函数
System.out.println("构造函数"+a+" "+b);
}
int b = 1; //定义一般变量
public void doSay() { //一般函数方法
// TODO Auto-generated method stub
System.out.println("一般函数方法"+a+" "+b);
}
{ //一般运算
System.out.println("一般代码块"+a+" "+b);
}
public static void main(String[] args) {
A a = new A();
a.doSay();
A.doTell();
}
}

结果解释:第一行,静态代码块2,说明静态常量优先于静态代码块;
第二行,一般代码块2 1,说明一般常量加载优先于一般代码块;
第三行,构造函数2 1,说明静态常量和一般常量优先于构造函数;
第四五行,为方法调用不做比较;
现在可以知道的顺序有:静态常量>静态代码块>构造函数;
一般常量>一般代码块>构造函数。
现在将测试代码修改为:
public class A {
static int a = 2; //定义静态变量
private static void doTell(){ //静态方法
System.out.println("静态方法"+a);
}
static{ //静态代码块
System.out.println("静态代码块"+a);
}
public static void main(String[] args) {
}
}
结果如下:

结果解释:打印结果说明,类A在加载过程中,就已经将静态常量和静态代码块执行了,而静态方法没有执行,
联系之前的测试结果可以得出结论:
静态常量>静态代码块>一般常量>一般代码块>构造函数
而类中的静态方法和一般方法只有在调用时才会去执行。


被折叠的 条评论
为什么被折叠?



