代码说事 之 创办java对象的初始化顺序

代码说事 之 创建java对象的初始化顺序
package util;
/**
 * 类初始化顺序:
 *父类静态代码块--->子类静态代码块--->父类代码块--->父类构造方法--->子类
 *代码块--->子类构造方法
 *1.  父类静态成员和静态初始化块 ,按在代码中出现的顺序依次执行 
 *2.  子类静态成员和静态初始化块 ,按在代码中出现的顺序依次执行 
 *2.  父类实例成员和实例初始化块 ,按在代码中出现的顺序依次执行 
 *4.  父类构造方法
 *5.  子类实例成员和实例初始化块 ,按在代码中出现的顺序依次执行 
 *6.  子类构造方法
 * @author zhiziwei
 * 
 */
public class ObjectInit {
	public ObjectInit(){
		System.out.println("ObjectInit构造方法");
	}
	public static void main(String[] arg0){
		new B();
		System.out.println("----------------------------");
		new B();
	}
}
class A{
	//static ObjectInit oi = new ObjectInit();//此时,“ObjectInit
               //构造方法”输出在"A static 代码块"上边
	static{
		System.out.println("A static 代码块");
	}//只执行一次
	static ObjectInit oi = new ObjectInit();//此时,“ObjectInit构
           //造方法”输出在"A static 代码块"下边
	protected String s = "先于父类代码块声明并初始化";
	{
		System.out.println("A 代码块");
		System.out.println("A 实例变量s输出:"+s);
	}//对象被创建几次,执行几次
	public A(){
		System.out.println("A 构造方法");
	}
}
class B extends A{
	static {
		System.out.println("B static 代码块");
	}
	{
		System.out.println("B 代码块");
	}
	public B(){
		System.out.println("B 构造方法");
	}
}
输出结果:
A static 代码块
ObjectInit构造方法
B static 代码块
A 代码块
A 实例变量s输出:先于父类代码块声明并初始化
A 构造方法
B 代码块
B 构造方法
----------------------------
A 代码块
A 实例变量s输出:先于父类代码块声明并初始化
A 构造方法
B 代码块
B 构造方法