一个java类的加载过程

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) {

  }
}



其中只保留的静态数据和main方法(方法体为空)


结果以下: 方法

结果解释:打印结果说明,类A在加载过程当中,就已经将静态常量和静态代码块执行了,而静态方法没有执行,

联系以前的测试结果能够得出结论:


                         静态常量>静态代码块>通常常量>通常代码块>构造函数

而类中的静态方法和通常方法只有在调用时才会去执行。

相关文章
相关标签/搜索