java类的加载过程
2014-10-11 20:30
155 查看
已经写过“静态代码块、非静态代码块以及构造函数的加载顺序”了,接下来再看看java类的加载过程。
先看Parent类代码:
Child()来创建一个实例,因为父类中没有非静态代码块,只有构造方法和非静态变量,所以按编码的顺序对a初始化为10,b初始化为0,然后执行父类的构造方法。这也是为什么父类中构造方法输出的a的值为10而不是168的原因,因为创建实例的时候重新初始化了。父类的构造方法以及非静态变量初始化完以后,按同样的顺序去初始化子类中的构造方法和非静态变量,当然这个也是按照编码的顺序来初始化的。有人可能有疑问为啥输出结果a为168,b为188。这是因为a的修饰符是private,所以子类中的a跟父类中a没有任何关系,他们只是同名罢了。那为什么这里a=168呢?这是因为子类在初始化静态变量a的时候调用父类发print()方法对a赋值为168了。至于b,那是因为b的修饰符是public,可以把值从父类中带到子类里来,所以b是188。
总结类的加载顺序:
1.按编码顺序递归加载类中的静态变量,静态代码块,静态方法。
2.进行实例化的时候按编码顺序递归加载类中的非静态变量,非静态代码块,非静态方法。
参考资料:http://wenku.baidu.com/link?url=GfZNryq1rwLdUL4bBOt3HOwBzfRqDDEFa5LxUSux8uG20cmgheMgsvmCMHSzVAtt1nEuwa1dAX8aV0H7TTimE51SxlQdH7imlNO6vQOtExm
声明:
1.原创内容,转载请注明原文链接
2.摩罗不写博客,所有内容只是摩罗笔记,如有错误或者您有更好的意见,欢迎指正。
欢迎关注行者摩罗微信公众号(xingzhemoluo),共同交流编程经验,扫描下方二维码即可;
先看Parent类代码:
public class Parent { private int a = 10; public int b; public Parent() { System.out.println("这是父类中的构造方法中的a的值为:" + a + " b的值为:" + b); b = 188; } static int x = print("这是父类在初始化静态变量x!"); public static int print(String str) { System.out.println(str); return 168; } }Child类代码:
public class Child extends Parent{ private static int a = print("这是子类在初始化静态变量a"); public Child() { System.out.println("这是子类中的构造方法a的值为:" + a + " b的值为:" + b); b++; } private static int y = print("这是子类在初始化静态变量y!"); public static void main(String[] args) { System.out.println("摩罗开始测试类的加载顺序了"); new Child(); } }执行结果:
这是父类在初始化静态变量x! 这是子类在初始化静态变量a 这是子类在初始化静态变量y! 摩罗开始测试类的加载顺序了 这是父类中的构造方法中的a的值为:10 b的值为:0 这是子类中的构造方法a的值为:168 b的值为:188输出结果分析:之所以“摩罗开始测试类的加载顺序了”这个输出语句是在三个静态变量的初始化之后,是因为类在加载的时候是先递归加载父类的静态变量和静态代码块,然后在加载子类的静态变量和子类的静态代码块。至于静态变量以及静态代码块的顺序是平级的,按编码的顺序进行初始化。非静态变量,非静态代码块以及构造方法则是在产生实例对象以后才加载。所以当我们运行程序的时候先递归加载静态变量以及静态代码块,当然这个顺序是递归加载的。所以先输出“这是父类在静态初始化静态变量x”,然后再输出“这是子类在初始化变量a”以及“这是子类在初始化静态变量y!”。接着输出“摩罗开始测试类的加载顺序了”,然后开始执行new
Child()来创建一个实例,因为父类中没有非静态代码块,只有构造方法和非静态变量,所以按编码的顺序对a初始化为10,b初始化为0,然后执行父类的构造方法。这也是为什么父类中构造方法输出的a的值为10而不是168的原因,因为创建实例的时候重新初始化了。父类的构造方法以及非静态变量初始化完以后,按同样的顺序去初始化子类中的构造方法和非静态变量,当然这个也是按照编码的顺序来初始化的。有人可能有疑问为啥输出结果a为168,b为188。这是因为a的修饰符是private,所以子类中的a跟父类中a没有任何关系,他们只是同名罢了。那为什么这里a=168呢?这是因为子类在初始化静态变量a的时候调用父类发print()方法对a赋值为168了。至于b,那是因为b的修饰符是public,可以把值从父类中带到子类里来,所以b是188。
总结类的加载顺序:
1.按编码顺序递归加载类中的静态变量,静态代码块,静态方法。
2.进行实例化的时候按编码顺序递归加载类中的非静态变量,非静态代码块,非静态方法。
参考资料:http://wenku.baidu.com/link?url=GfZNryq1rwLdUL4bBOt3HOwBzfRqDDEFa5LxUSux8uG20cmgheMgsvmCMHSzVAtt1nEuwa1dAX8aV0H7TTimE51SxlQdH7imlNO6vQOtExm
声明:
1.原创内容,转载请注明原文链接
2.摩罗不写博客,所有内容只是摩罗笔记,如有错误或者您有更好的意见,欢迎指正。
欢迎关注行者摩罗微信公众号(xingzhemoluo),共同交流编程经验,扫描下方二维码即可;
相关文章推荐
- 实例解析-Java程序的加载过程
- 优化Java applets 加载过程
- 黑马程序员--05.类加载器--03【从JVM加载类的过程再看类加载器】【从Java源码再看双亲委派模型】
- Java 类加载 初始化过程
- java程序的加载过程
- 解析Java Class Loader 类加载过程
- 一个java类的加载过程
- Java--Java程序的加载过程
- Java类的加载过程
- java加载class过程
- java web.xml被文件加载过程,各节点加载顺序总结
- Java 程序的加载运行过程
- 通过类字面常量解释接口常量为什么只能定义为static final,类加载过程---Thinking in java
- java类加载过程
- Java程序的加载过程
- 实例解析-Java程序的加载过程
- 通过类字面常量解释接口常量为什么只能定义为static final,类加载过程---Thinking in java
- java类加载过程
- java 类加载全过程之第二步 验证
- java程序的加载过程