我知道在JVM识别类的方式是通过classLoader和全类名识别的,那么当一个类由两个不同的classLoader加载后。
对这个类初始化时,JVM会选择对哪个类进行初始化?其依据是什么?
两个classLoader加载的Class对象在内存中的位置有什么区别吗?
例如:
有人提出看工程结构,我把加载器和被加载对象的结构放出来吧:
被加载的类也是在classpath下的
这里的初始化可以理解为,类加载的最后一步(调用<clinit>
),如果是两个不同的ClassLoad加载的话那么<clinit>
会被执行两次,加载的Class
对象在方法区(永久代),并且会对应两个Class
对象.
如果是重载findClass
方法代码运行出来的结果最后应该是两个true
.上述代码,因为class
文件最终是在classpath
下,所以都是交给AppLoader去加载,如果需要呈现效果,需要把class
文件挪一个位置,挪到不在classpath
.楼主是重载loadClass
方法
简单来说是这样的:
1、ClassLoad可以有很多,而且它们之间存在层级关系,最顶层的叫做BootClassLoad。
2、每层ClassLoad都用自己的工作范围。
3、每个ClassLoad中都有一个上级ClassLoad的引用。
4、当某一个ClassLoad开始工作时(加载Class),他会首先调用上级ClassLoad来Load Class,层层向上,直到顶层。
5、只有当上级ClassLoader没能在职责范围内Load到指定Class时,下级ClassLoader才会在自己的职责范围内来Load。
更多内容,搜索引擎检索关键字“双亲委派模型”即可。
15 回答8.4k 阅读
8 回答6.2k 阅读
1 回答4k 阅读✓ 已解决
3 回答6k 阅读
3 回答2.2k 阅读✓ 已解决
2 回答3.1k 阅读
2 回答3.8k 阅读
偏题了 我觉得这代码很工整 看上去很舒服