其中类加载的过程包括了加载、验证、准备、解析、初始化五个阶段。
tip:jvm分为堆、栈、方法区,常量池存在于方法区中;
1.类加载过程:
a.jvm现在方法区中找有没有对应的.class存在,如果没有则需要把相关.class加载到方法区(通过包路径获取.class文件);
b.在.class加载到方法区,先加载非静态内容,再加载静态内容;
c.加载非静态内容:把.class中的所有非静态内容加载到方法区下的非静态区域内;
d.加载静态内容:
1、把.class中的所有静态内容加载到方法区下的静态区域内;
2、静态内容加载完成之后,对所有的静态变量进行默认初始化;
3、所有的静态变量默认初始化完成之后,再进行显式初始化;
4、当静态区域下的所有静态变量显式初始化完后,执行静态代码块;
e.静态区域加载完成以后,整个类就加载完成;
2.类卸载过程:
当类的Class对象不再被引用,CLass对象就结束了生命周期,类在方法区中的数据也会被卸载,从而结束类的生命周期;
a.由jvm自带的类加载器加载的类,不会被卸载(bootClassLoader,ext...、app...);
原因是:jvm会始终引用这些类加载器,而类加载器引用Class对象,因此这些Class对象始终是引用状态;
3.对象创建过程:
a.在堆中开辟空间;
b.给空间分配地址;
c.把对象所有非静态成员加载到所开辟的空间下;
d.对非静态成员初始化;
e.调用构造函数;
f.在构造函数入栈执行时,分为两部分:先执行构造函数中的隐式三步,再执行构造函数中书写的代:
1、隐式三步:
1.1、执行super();
1.2、对所有非静态成员进行显示初始化;
1.3、执行构造代码块;
2、执行构造方法逻辑;
f.在整个构造函数执行完并弹栈后,把空间分配的地址赋值给一个引用对象;
如图:.class文件被加载到方法区中,再被classLoader所加载,在类加载器的内部实现中,用一个Java集合来存放所加载类的引用。另一方面,一个Class对象总是会引用它的类加载器。调用Class对象的getClassLoader()方法,就能获得它的类加载器。由此可见,Class实例和加载它的加载器之间为双向关联关系。
参考:http://blog.csdn.net/ns_code/article/details/17881581
https://www.cnblogs.com/mengdd/p/3594608.html