Java子类继承父类,静态代码块,代码块,构造方法执行顺序

最近在做笔试时碰到这样一道题目

public class Test {
 
	public static void main(String[] args) {
		Son son = new Son();
	}
 
}
class Father{
	static {
		System.out.println("A");            
	}	
	{
		System.out.println("B");            
	}
	Father(){
		System.out.println("C");              
	}
}
class Son extends Father{
	static {
		System.out.println("a");            
	}	
	{
		System.out.println("b");            
	}
	Son(){
		System.out.println("c");              
	}
}

问初始化Son对象,打印出来的顺序应该是怎么样的,当时一下没想起来,现在记下来加深印象。

首先记住这些:

1.父静态代码块:父静态代码块是类加载时最先执行的部分,且只执行一次。
2.子静态代码块:子静态代码块紧接着父静态代码块执行,同样只执行一次。
3.父构造代码块:当调用子类的构造方法时,首先执行的是父类的构造代码块。
4.父构造方法:紧接着父类的构造代码块,执行父类的构造方法。
5.子构造代码块:父类构造方法执行完毕后,执行子类的构造代码块。
6.子构造方法:最后执行子类的构造方法。

所以打印出来的语句顺序是:

A
a
B
C
b
c

为什么是这样的顺序呢?
因为当虚拟机加载类时,会首先执行类中的静态代码块。静态代码块的执行顺序是按照它们在类中出现的顺序。
使用new关键字创建Son类的对象时,会触发以下顺序的执行:
将类加载进内存中时,Father类先于Son类,所以首先执行父类Father的静态代码块。
然后执行子类Son的静态代码块。
接下来,执行父类Father的构造代码块,然后是父类的构造方法。
最后,执行子类Son的构造代码块和构造方法

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Test.java文件的代码: ``` public class Test { public static void main(String[] args) { Leaf leaf1 = new Leaf(); Leaf leaf2 = new Leaf(); } } class Root { static { System.out.println("Root的静态代码块"); } { System.out.println("Root的实例代码块"); } public Root() { System.out.println("Root的构造函数"); } } class Mid extends Root { static { System.out.println("Mid的静态代码块"); } { System.out.println("Mid的实例代码块"); } public Mid() { this("调用重载的构造器"); System.out.println("Mid的无参构造函数"); } public Mid(String s) { System.out.println("Mid的带参构造函数:" + s); } } class Leaf extends Mid { static { System.out.println("Leaf的静态代码块"); } { System.out.println("Leaf的实例代码块"); } public Leaf() { super("调用父类指定的构造器"); System.out.println("Leaf的无参构造函数"); } } ``` 输出结果为: ``` Root的静态代码块 Mid的静态代码块 Leaf的静态代码块 Root的实例代码块 Root的构造函数 Mid的实例代码块 Mid的带参构造函数:调用重载的构造器 Mid的无参构造函数 Leaf的实例代码块 Leaf的带参构造函数:调用父类指定的构造器 Leaf的无参构造函数 Root的实例代码块 Root的构造函数 Mid的实例代码块 Mid的带参构造函数:调用重载的构造器 Mid的无参构造函数 Leaf的实例代码块 Leaf的带参构造函数:调用父类指定的构造器 Leaf的无参构造函数 ``` 可以看到,初始化代码块和构造函数的执行顺序符合题目中所给的加载顺序。同时,Leaf类使用super显示调用其父类指定的构造器,而Mid类使用this调用重载的构造器,验证了题目中的要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值