java对象创建时代码(静态方法,成员方法,构造方法等)的加载顺序。

本文详细探讨了Java中对象创建时的代码加载顺序,通过具体测试案例,验证了静态代码、非静态代码和构造方法的加载顺序,以及当存在继承关系时,父类和子类代码的加载顺序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先说结论。

对象创建时代码的加载顺序为:静态代码-->非静态代码-->构造方法。

若继承了父类,则加载顺序为:父类的静态的代码-->子类的静态的代码-->父类内部非静态代码-->父类的构造方法-->子类的非静态代码-->子类的构造方法。

其中,静态代码包括(静态方法,静态变量,静态代码块等),非静态代码即(成员方法,成员变量,成员代码块等),同一种代码,写在上面的先加载。

为了研究对象加载时候,静态代码块,静态变量,构造方法,成员方法等各个代码的加载顺序,进行如下测试:

测试一:

package test;

public class java父类及子类代码的加载顺序 {
	public static void main(String[] args) {
		Parent parent =new Parent();
	}
}

class Parent{
	static{
		System.out.println("父类静态代码块1");
	}
	static String tem=aa();
	
	static String aa(){
		System.out.println("父类的静态方法");
		return "";
	}
	public Parent(){
		System.out.println("父类的构造方法");
	}
	static{
		System.out.println("父类静态代码块2");
	}
	
	{
		System.out.println("父类非静态代码块1");
	}
	
	String temp = tt();		
	String tt(){
		System.out.println("父类的成员方法");
		return "成员方法";
	}
	{
		System.out.println("父类非静态代码块2");
	}
}

运行结果为:

父类静态代码块1
父类的静态方法
父类静态代码块2
父类非静态代码块1
父类的成员方法
父类非静态代码块2
父类的构造方法

因此可以得到结论:

对象加载时代码的加载顺序为:静态代码-->非静态代码-->构造方法。

测试二:

package test;

public class java父类及子类代码的加载顺序 {
	public static void main(String[] args) {
		Childern childern =new Childern();
	}
}

class Parent{
	static{
		System.out.println("父类静态代码块1");
	}
	static String tem=aa();
	
	static String aa(){
		System.out.println("父类的静态方法");
		return "";
	}
	public Parent(){
		System.out.println("父类的构造方法");
	}
	static{
		System.out.println("父类静态代码块2");
	}
	
	{
		System.out.println("父类非静态代码块1");
	}
	
	String temp = tt();		
	String tt(){
		System.out.println("父类的成员方法");
		return "成员方法";
	}
	{
		System.out.println("父类非静态代码块2");
	}
}


class Childern extends Parent{
	static{
		System.out.println("子类静态代码块1");
	}
	static String tem=aa();
	
	static String aa(){
		System.out.println("子类的静态方法");
		return "";
	}
	public Childern(){
		System.out.println("子类的构造方法");
	}
	static{
		System.out.println("子类静态代码块2");
	}
	
	{
		System.out.println("子类非静态代码块1");
	}
	
	String temp = TT();		
	String TT(){
		System.out.println("子类的成员方法");
		return "成员方法";
	}
	{
		System.out.println("子类非静态代码块2");
	}
}

测试结果:

父类静态代码块1
父类的静态方法
父类静态代码块2
子类静态代码块1
子类的静态方法
子类静态代码块2
父类非静态代码块1
父类的成员方法
父类非静态代码块2
父类的构造方法
子类非静态代码块1
子类的成员方法
子类非静态代码块2
子类的构造方法

可以得出结论:对象在加载时,若继承了父类。加载顺序为:父类的静态的代码-->子类的静态的代码-->父类内部非静态代码-->父类的构造方法-->子类的非静态代码-->子类的构造方法。

http://blog.youkuaiyun.com/methods2011/article/details/8584463 Java中的继承与静态static等的执行先后顺序的面试题 java面试题静态加载顺序构造方法 继承与static 面试题目如下:请写出程序执行完成之后的结果。 package extend; public class X { Y y=new Y(); static{ System.out.println("tttt"); } X(){ System.out.println("X"); } public static void main(String[] args) { new Z(); } } class Y{ Y(){ System.out.println("Y"); } } class Z extends X{ Y y=new Y(); static{ System.out.println("tt"); } Z(){ System.out.println("Z"); } } 先不告诉最后结果,我们先来分析下。一步一步推出结果。 1.首先分析一段程序的执行后的结果,我们得先找到程序的入口,然后才能着手分析。 也就是main()方法。 2.我们发现main()方法在X中,要执行main()方法,还得先将X加载到内存中。 3.X加载完成后,会做什么事情呢?别急,先来看看static的作用,不知道吧。告诉你:static就是在被第一次加载的候执行,以后就不再执行。 4.知道了static的作用,那么X被加载,那么就会先执行X静态属性和静态语句块(static),执行先后顺序看谁在前面就先执行谁。只在此执行,以后都不会。 5.所以一个输出结果为tttt,没问题了吧。 6.X的static语句块执行完了,就该执行main()方法啦。 7.new Z();此方法被执行。 8.既然new Z();那么Z就要被加载。因为Z继承X。所以必须先加载X才行。因为X已经被加载。所以此不用再加载X了。Z加载好了就要执行Z的static语句块 9.那么就会打印出tt了吧。 10.都加在完后就要实例化对象了。 11.实例化Z之前,还得先实例化X对吧。因为子构造方法都会调用父构造方法。 12.那就先实例化X吧。 13.执行X方法前还得先初始化对不。也就是获取所有属性。那么X的属性Y就会获取。 14.即X的Y y=new Y();要被执行。也就是会打印Y。 15.接着执行System.out.println("X"); 16.然后就是执行Z的构造方法 17.同样先获取Z的属性Y y=new Y();打印Y。 18.再执行System.out.println("Z"); 整个过程就是这样了。现在知道结果了吧: tttt tt Y X Y Z http://snow4909.diandian.com/post/2013-02-17/40049419937 记住,面试有可能会标出一些语句的,让你选择这些语句的执行顺序。不过只要知道原理,就没什么难的了。 执行先后顺序: 1、加载到内存static 加载进内润 2、调用构造方法先调用父构造方法,在调用子构造方法 3、初始化,先初始化的属性成员,在执行构造方法
### Java静态方法静态代码块和构造方法的执行顺序 在 Java 中,程序运行加载的过程决定了静态方法静态代码块以及构造方法的执行顺序。以下是详细的分析: #### 加载过程中的执行顺序 当一个被加载到 JVM 中,其初始化阶段会按以下顺序执行: 1. **静态代码块**:静态代码块会在加载被执行一次,并且按照它们在源码中定义的顺序依次执行[^2]。 2. **静态变量赋值**:如果存在静态成员变量(如 `static` 字段),这些字段会被初始化并分配默认值或显式指定的初始值[^3]。 3. **静态方法调用**:静态方法可以在加载完成后通过名直接调用,或者由其他地方触发调用。 只有当创建对象实例才会涉及构造方法及其相关部分: 4. **构造代码块**:每次创建对象都会执行构造代码块,它位于构造方法之前[^1]。 5. **构造方法**:最后执行的是与当前对象关联的具体构造方法[^1]。 因此,在整个生命周期来看,完整的执行流程可以总结如下: - 静态代码块 → (可能存在的) 静态方法调用 → 构造代码块 → 构造方法。 需要注意的一点是,尽管静态方法可以通过对象来访问,但实际上它是属于级别的操作;也就是说即使没有实际的对象存在也能正常工作[^2]。 下面给出一段示例代码展示这种行为模式: ```java public class ExecutionOrderExample { static { System.out.println("Static block executed"); } { System.out.println("Instance initialization block executed"); } public ExecutionOrderExample(){ System.out.println("Constructor called"); } public static void main(String[] args){ System.out.println("Before object creation"); // 创建第一个对象前后的打印语句用于区分不同间点的行为 new ExecutionOrderExample(); System.out.println("\nCalling a static method now:"); callStaticMethod(); // 再次创建另一个对象观察重复情况下的表现差异 new ExecutionOrderExample(); } public static void callStaticMethod(){ System.out.println("Inside the static method."); } } ``` 此代码片段展示了从启动应用程序直到完成两个独立对象构建期间各个组件是如何交互工作的。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值