基础中的基础
但是如果基础都不能简单通俗的说出来的话也未必是真正掌握了。
一句话解释一下
Java的类加载机制就是将".class"文件加载到内存中(JVM中的方法区), 并且在JVM的堆上生成一个java.lang.Class对象. 用来封装相关的数据和方法。
Java类加载的过程
1. 加载
加载字节流到内存中,放在方法区/metaspace
这一步会校验是否是Class结构,如果不是会抛出ClassForMatError
2. 链接
将原始定义类信息转化到JVM内存中
2.1 验证
验证加载进来的字节信息是否符合JVM规范
2.2 准备
创建接口或类中的静态变量,并初始化静态变量的初试值
注意这里不会执行更进一步比如putStatic之类的JVM指令
2.3 解析
解析符号引用为直接引用
3. 初始化
Java类加载的三个机制
- 双亲委派机制
- 可见性
- 单一性
其中比较有名的是双亲委派机制
先说下他的定义, 当加载器加载一个类的时候,除非父类加载器不能加载,否则就由父类加载器来加载。
比较逗的是这个双亲委派机制的英文原文叫"The parent-delegation model"
周志明老师的书里翻译成了,双亲委派机制,然后也是周老师的书过于普及,双亲委派机制就这么开始叫起来了(不知道是不是还有别的源头这么叫)
然后网上就有声音是说不该这么叫,parent又不是parentes,只能叫单亲加载机制,而且你看上图也只有单向的路径。
看一下loadClass的源码
try {
if (parent != null) {
c = parent.loadClass(name, false);
} else {
c = findBootstrapClassOrNull(name);
}
} catch (ClassNotFoundException e) {
// ClassNotFoundException thrown if class not found
// from the non-null parent class loader
}
因为Boot Class-Loader 是C++写的,Java代码中无法识别到,只能使用null来代替,所以这里的双亲委派在这里其实有两条路径,叫双亲委派,可以体现出对Boot Class-Loader 的最终依赖。
至于可见性和单一性,其实也都是基于双亲委派机制出发去说的,
可见性是,父类加载器对子类不可见,但反之可见,这点可以基于隔离性思考下。
单一性是指,由于可见性,子类对父类可见,所以父类加载过的类型,子类便不会再加载了。