<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    瘋狂

    STANDING ON THE SHOULDERS OF GIANTS
    posts - 481, comments - 486, trackbacks - 0, articles - 1
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    Java ClassLoader基礎知識

    Posted on 2011-10-20 11:27 瘋狂 閱讀(1043) 評論(0)  編輯  收藏 所屬分類: java
    Java中一共有四個類加載器,之所以叫類加載器,是程序要用到某個類的時候,要用類加載器載入內存。
        這四個類加載器分別為:Bootstrap ClassLoaderExtension ClassLoaderAppClassLoader
    URLClassLoader,他們的作用其實從名字就可以大概推測出來了。其中AppClassLoader在很多地方被叫做System ClassLoader

    Bootstrap ClassLoader是在JVM開始運行的時候加載java的核心類,是用C++編寫的,它用來加載核心類庫,在JVM源代碼中這樣寫道:
    static const char classpathFormat[] =
    "%/lib/rt.jar:"
    "%/lib/i18n.jar:"
    "%/lib/sunrsasign.jar:"
    "%/lib/jsse.jar:"
    "%/lib/jce.jar:"
    "%/lib/charsets.jar:"
    "%/classes";
    Extension ClassLoader是用來加載擴展類,即/lib/ext中的類。
    AppClassLoader用來加載Classpath的類,是和我們關系最密切的類。
    URLClassLoader用來加載網絡上遠程的類,暫且不討論。

    它們之間的關系:

    1.Parent-Child,按順序從大到小。不是簡單的繼承關系。

    2.ClassLoader有個getParent的方法,但是Ext ClassLoader調用后得到的是null,bootstrap是JVM自己的,用戶看不到。

    3.classloader的委托機制:當等級比較低的ClassLoader要加載某個類的時候,它首先會請求Parent加載器來加載,Parent再請求它的Parent
    比如現在Ext要加載了,它往上請求。如果最大的Bootstrap找不到,那么Boot會叫Ext自己找找,Ext找不到,是不會讓下一級的App去找的,此時就報出ClassNotFoundException

    4.類A調用類B,B會要求調用它的類的類加載器來加載它,也就是B會要求加載A的加載器來加載B。這就會有個問題,如果他們在一起,那沒關系,肯定某個classloader會把它們倆都加載好。但是如果A在/lib/ext文件夾中,而B在Classpath中呢?過程是這樣的首先加載A,那么一層層上到Bootstrap Classloader,boot沒找到所以ext自己找,找到了,沒問題;加載B,因為A調用了B,所以也從bootstrap來找,沒找到,然后A的ext classloader來找還是沒找到,但是再也不會往下調用了,于是報出ClassNotFoundException。
    但是現實生活中有很多應用,比如JDBC核心方法在核心庫而驅動在擴展庫,是必定在兩個地方的,那怎么辦呢?要用到Context ClassLoader我們在建立一個線程Thread的時候,可以為這個線程通過setContextClassLoader方法來指定一個合適的classloader作為這個線程的context classloader,當此線程運行的時候,我們可以通過getContextClassLoader方法來獲得此context classloader,就可以用它來載入我們所需要的Class。默認的是system classloader。利用這個特性,我們可以“打破”classloader委托機制了,父classloader可以獲得當前線程的context classloader,而這個context classloader可以是它的子classloader或者其他的classloader,那么父classloader就可以從其獲得所需的 Class,這就打破了只能向父classloader請求的限制了。這個機制可以滿足當我們的classpath是在運行時才確定,并由定制的 classloader加載的時候,由system classloader(即在jvm classpath中)加載的class可以通過context classloader獲得定制的classloader并加載入特定的class(通常是抽象類和接口,定制的classloader中是其實現),例如web應用中的servlet就是用這種機制加載的.
    轉載自:http://m.tkk7.com/clraychen/archive/2008/02/20/180868.html
    主站蜘蛛池模板: 国产精品亚洲玖玖玖在线观看| 亚洲精品动漫人成3d在线| 亚洲精品成a人在线观看夫| 亚洲AV伊人久久青青草原| 日本免费久久久久久久网站| 亚洲一区电影在线观看| 亚洲国产成人五月综合网 | 国产精品怡红院永久免费| 亚洲av成人无码网站…| 亚洲欧洲自拍拍偷午夜色无码| 日韩精品成人无码专区免费 | 免费一级全黄少妇性色生活片| 亚洲国产成人精品无码区在线观看| 性做久久久久久久免费看| jizz18免费视频| wwwxxx亚洲| 亚洲AV无码乱码在线观看富二代 | 国产91免费在线观看| 特级毛片aaaa免费观看| 亚洲成人一级电影| 国产亚洲精品AA片在线观看不加载| 最近2019中文字幕mv免费看| 国产一精品一AV一免费| 黄色免费网址大全| 亚洲专区中文字幕| 亚洲av日韩av激情亚洲| 亚洲国产精品不卡毛片a在线| 100000免费啪啪18免进| 两个人看的www高清免费观看| 久久亚洲精品无码av| 亚洲第一页中文字幕| 亚洲精品国产精品乱码在线观看| 午夜视频免费观看| 四虎1515hh永久久免费| 精品国产免费一区二区三区香蕉 | 激情内射亚洲一区二区三区| 4338×亚洲全国最大色成网站| 免费高清小黄站在线观看| 亚洲视频免费在线播放| 精品视频在线免费观看| 精品熟女少妇aⅴ免费久久|