java中代码执行顺序
之前对于静态代码块,构造代码块,普通代码块,以及类的初始化等代码执行顺序一直不是特别清楚,在此整理,方便复习!
执行顺序:父类 -->子类静态属性&静态代码块 -->普通属性&构造代码块-->构造方法 -->普通代码块(所在方法被调用才执行)原因分析:静态代码块:在java中使用static关键字声明的代码块{}。static { System.out.println("静态代码块");}
代码级别:成员级别==在类加载时执行,且只执行一次==
(对于类加载不是很清楚的小伙伴们可先看这篇博客:类加载)
class Parent {static { System.out.println("A");}Parent(){ System.out.println("sdfsaf");}static { System.out.println("B");}}public class ExplicitStatic {public static void main(String[] args) { new Parent();//第一次执行,触发了类加载 System.out.println("=========华丽的分割线========="); new Parent();//第二次实例化,不再触发类的加载,不再执行静态代码块}}
运行结果:
public class Test01 {{ System.out.println("我是构造代码块");}public static void main(String[] args) { new Test01();}}
代码级别:成员级别构造代码块在创建对象时被调用,每次创建对象都会被调用构造代码块的执行次序优先于类构造方法
class Test02{ { System.out.println("我是 父类 构造代码块"); }}public class Test01 extends Test02{ { System.out.println("我是 子类 构造代码块1"); } Test01(){ System.out.println("我是无参构造方法"); } Test01(int v){ System.out.println("我是有参构造方法"); } static { System.out.println("静态代码块"); } { System.out.println("我是 子类 构造代码块2"); } public static void main(String[] args) { new Test01(); System.out.println("===================华丽的分割线==================="); new Test01(6);//每次创建对象都会执行构造代码块 }}
运行结果:
public void method() { { System.out.println("普通代码块1"); } ....}
代码级别:方法级别普通代码块和一般的语句执行顺序由他们在代码中出现的次序决定--“先出现先执行”
class Test02{ { System.out.println("我是 父类 构造代码块"); }}public class Test01 extends Test02{ { System.out.println("我是 子类 构造代码块"); } static { System.out.println("静态代码块"); } public void method(){ { System.out.println("普通代码块1"); } System.out.println("普通方法体"); { System.out.println("普通代码块2"); } } public static void main(String[] args) { new Test01(); System.out.println("===================华丽的分割线==================="); new Test01().method();//被调用才会执行方法中的代码块 }}
运行结果:
对象实例化时的顺序:
1,父类的静态成员变量和静态代码块加载
2,子类的静态成员变量和静态代码块加载
3,父类成员变量和构造代码块加载
4,父类的构造方法加载
5,子类成员变量和构造代码块加载
6,子类的构造方法加载
知识点汇总 ,测试源码如下:class Parent2 { { System.out.println("父类 构造代码块1");//5 } Parent2() { System.out.println("父类 的无参构造方法");//7 } static { System.out.println("父类 的静态代码块1");//1 } { System.out.println("父类 构造代码块2");//6 } static { System.out.println("父类 的静态代码块2");//2 }}public class ExplicitStatic extends Parent2 { static { System.out.println("子类 的静态代码块1");//3 } ExplicitStatic() {//15 super();//可省略 System.out.println("子类 无参构造方法");//16 } ExplicitStatic(int v) {//14 this();//即 执行15 System.out.println("子类 有参构造方法");//17 } private int initA() { System.out.println("子类 的属性初始化调用 普通方法A");//9 return 0; } static { System.out.println("子类 的静态代码块2");//4 } private int initB() { System.out.println("子类 的属性初始化调用 普通方法B");//12 return 0; } int a = initA();//8 { System.out.println("子类 的构造代码块1");//10 } int b = initB();//11 { System.out.println("子类 的构造代码块2");//13 } public void method() { { System.out.println("子类 的普通代码块1"); } System.out.println("子类 的普通方法method"); { System.out.println("子类 的普通代码块2"); } } public static void main(String[] args) { new ExplicitStatic(100); System.out.println("================="); new ExplicitStatic().method();}
运行结果如图:
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。