1静态常量,2静态方法,3静态代码块,4类的构造函数,5通常常量,6通常方法,7通常代码块 java
这些在编译中的顺序是怎样的,一下将要用代码来解释一下: 函数
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,说明通常常量加载优先于通常代码块; spa
第三行,构造函数2 1,说明静态常量和通常常量优先于构造函数; code
第四五行,为方法调用不作比较; 编译
如今能够知道的顺序有:静态常量>静态代码块>构造函数; class
通常常量>通常代码块>构造函数。 变量
如今将测试代码修改成: 构造函数
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在加载过程当中,就已经将静态常量和静态代码块执行了,而静态方法没有执行,
联系以前的测试结果能够得出结论:
静态常量>静态代码块>通常常量>通常代码块>构造函数
而类中的静态方法和通常方法只有在调用时才会去执行。