当前位置: 首页 > article >正文

静态代码块、实例代码块、构造方法的执行顺序

这是静态代码块,被static关键字修饰的一段代码
静态代码块只会执行一次,即在第一次类加载的时候执行

public class A{
	static{
		System.out.println("A class static ...")
	}
}

这是实例代码块
每次在创建一个实例时都会被执行一次,构造方法前执行

public class C{

	{
		System.out.println("C class example...")
	}
	
}

当一个类中同时存在静态代码块、实例代码块、构造方法时,执行顺序是什么呢?

class A {  
	// 静态代码块
    static {  
        System.out.println("A class static ...");  
    }  

	// 实例代码块
    {        System.out.println("A class example");  
    }  
    
	// 构造方法
    public A() {  
        System.out.println("A class...");  
    }  
}

测试一下

public static void main(String[] args){
	new A();

	new A();
}

看执行结果

A class static ...
A class example
A class...
A class example
A class...

分析:

  1. 静态代码块会最先执行,即在此类被加载时执行静态代码块,由于这个类加载只执行一次,所以这个静态代码块只会执行一次
  2. 实例代码块其次执行,每次创建此类的实例时,会在构造方法前执行
  3. 构造方法最后执行

来点更复杂的,父类和子类都存在静态代码块、实例代码块、构造方法时,执行顺序会是怎么样的?

class A {  
    static {  
        System.out.println("A class static ...");  
    }  
  
    {        System.out.println("A class example");  
    }  
  
    public A() {  
        System.out.println("A class...");  
    }  
  
}

public class B extends A {  
  
    static {  
        System.out.println("B class static ...");  
    }  
  
    {        System.out.println("B class example ...");  
    }  
  
    public B() {  
        System.out.println("B class ...");  
    }  
}

测试一下

public static void main(String[] args){
	new B();

	new B();
}

看执行结果

A class static ...
B class static ...
A class example
A class...
B class example ...
B class ...

A class example
A class...
B class example ...
B class ...

分析:

  1. 创建子类实例,首先会去加载父类,然后再加载子类,所以先执行父类的静态代码块,再执行子类的静态代码块
  2. 在执行子类构造方法前,会先去调用父类的构造方法,但是父类也存在实例代码块
  3. 所以在执行父类构造方法前,先执行父类的实例代码块,然后执行父类的构造方法
  4. 接下来再是子类的构造方法,子类也存在实例代码块,先执行子类的实例代码块,然后就是子类构造方法

总结:当创建子类实例时,三者的执行顺序依次是:

  1. 父类静态代码块
  2. 子类静态代码块
  3. 父类实例代码块
  4. 父类构造方法
  5. 子类实例代码块
  6. 子类构造方法

http://www.kler.cn/news/18566.html

相关文章:

  • Linux介绍及环境搭建
  • Liunx 使用命令连接Redis
  • 关于 std::condition_variable
  • web之iframe的那些事、打开外链、窗口、嵌入、iframe、location、href、replace、open、assign
  • KingbaseES V8R6备份恢复系列之 -- system-Id不匹配备份故障
  • Java引用类型(强引用,软引用,弱引用,虚引用)
  • 运维高可用架构的 6 大常规方案
  • 重新定义座舱智能化的下半场?谁能抓住弯道超车的窗口期
  • 《Kubernetes证书篇:基于cfssl工具集一键生成二进制kubernetes集群相关证书(方法一)》
  • MySQL:数学函数和字符串函数
  • VMware NSX Advanced Load Balancer (NSX ALB) 22.1.3 - 负载均衡平台
  • 从零构建自己的脚手架
  • 【多线程初阶三】简单了解wait和notify方法~
  • [Go语言实战]并发模式runner
  • iOS输入限制表情输入、最大字符、正则过滤
  • Geoffrey Hinton对于AI的警示 20230507
  • SQL 招聘网站岗位数据分析
  • 数据挖掘笔记
  • Spring-AOP
  • 文心一言 VS chatgpt (6)-- 算法导论2.3 1~2题
  • macOS的CAOpenGLLayer中如何启用OpenGL3.2 core profile
  • Oracle监控账号创建【Prometheus】
  • webstorm 创建harthat项目
  • AI 工具合辑盘点(七)持续更新 之 AI 音乐制作工具
  • 【运动规划算法项目实战】如何利用AABB作碰撞检测(附ROS C++代码)
  • SQL学习日记
  • 从文字到语义:文本分词和词性标注的原理与实现
  • Gradio的web界面演示与交互机器学习模型,安装和使用《1》
  • 拐点已至!被比亚迪赶超,大众中国打响「翻身战」
  • 单元测试 - 集成H2 Dao测测试