JVM源码分析--ClassLoader类加载器
本人原創,轉載請注明出處:https://www.cnblogs.com/javallh/p/10224187.html?
1、JDK已有類加載器:
?BootStrap ClassLoader (啟動類加載器)? 運行的是rt.jar? ?源碼由C++編寫,所以在java中讀取的時候以null表示
?Extension ClassLoader extends ClassLoader 運行的是%JAVA_HOME%/lib/ext/*.jar
?App ClassLoader extends ClassLoader 運行的是ClassPath
2、自定義類加載器 extends ClassLoader
?默認的加載順序:自定義類加載器--App ClassLoader--Extension ClassLoader--BootStrap ClassLoader? ? ? (遵循雙親委派模型,并無繼承關系!下面可以看源碼)
程序體現:
package com.cloud.rest;import lombok.var; import org.junit.Test;public class ClassLoaderTest {@Testpublic void classLoderTest() {var loader = ClassLoaderTest.class.getClassLoader();while (loader != null) {System.out.println(loader);loader = loader.getParent();}System.out.println(loader);}}如下效果分析:
sun.misc.Launcher$AppClassLoader@18b4aac2 sun.misc.Launcher$ExtClassLoader@3d04a311 null加載機制可以體現,為null的輸出是因為加載BootStrap ClassLoader的時候由于BootStrap無法讀取,所以使用null來表示,也可以這樣說:如果某個類的父類加載器輸出為null,則表示它的父類加載器為BootStrap ClassLoader,(注意:此時的父類為雙親委派模型的概念,并不是類的繼承)
轉載于:https://www.cnblogs.com/javallh/p/10224187.html
總結
以上是生活随笔為你收集整理的JVM源码分析--ClassLoader类加载器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 图像处理笔记(八)
- 下一篇: Swing企业员工工资管理系统v1.4(