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

先说结论。

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

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

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

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

测试一:

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.csdn.net/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、初始化,先初始化的属性成员,在执行构造方法
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值