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

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

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

    魚躍于淵

    First know how, Second know why !
    posts - 0, comments - 1, trackbacks - 0, articles - 49

    JavaClassLoader與Package機制

    Posted on 2008-09-20 09:09 魚躍于淵 閱讀(132) 評論(0)  編輯  收藏 所屬分類: 精品網(wǎng)摘

    [摘要] Java語言規(guī)定,在同一個包中的class,如果沒有修飾符,默認(rèn)為Package權(quán)限,包內(nèi)的class都可以訪問。但是這還不夠準(zhǔn)確。確切的說,只有由同一個ClassLoader裝載的class才具有以上的Package權(quán)限。
    [關(guān)鍵字]
    JavaClassLoader Package
      為了深入了解Java的ClassLoader機制,我們先來做以下實驗:

      package java.lang;

      public class Test {

      public static void main(String[] args) {

      char[] c = "1234567890".toCharArray();

      String s = new String(0, 10, c);

      }

      }

      String類有一個Package權(quán)限的構(gòu)造函數(shù)String(int offset, int length, char[] array),按照默認(rèn)的訪問權(quán)限,由于Test屬于java.lang包,因此理論上應(yīng)該可以訪問String的這個構(gòu)造函數(shù)。編譯通過!執(zhí)行時結(jié)果如下:

      Exception in thread "main" java.lang.SecurityException: Prohibited package name:

      java.lang

      at java.lang.ClassLoader.defineClass(Unknown Source)

      at java.security.SecureClassLoader.defineClass(Unknown Source)

      at java.net.URLClassLoader.defineClass(Unknown Source)

      at java.net.URLClassLoader.access$100(Unknown Source)

      at java.net.URLClassLoader$1.run(Unknown Source)

      at java.security.AccessController.doPrivileged(Native Method)

      at java.net.URLClassLoader.findClass(Unknown Source)

      at java.lang.ClassLoader.loadClass(Unknown Source)

      at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)

      at java.lang.ClassLoader.loadClass(Unknown Source)

      at java.lang.ClassLoader.loadClassInternal(Unknown Source)

      奇怪吧?要弄清為什么會有SecurityException,就必須搞清楚ClassLoader的機制。

      Java的ClassLoader就是用來動態(tài)裝載class的,ClassLoader對一個class只會裝載一次,JVM使用的ClassLoader一共有4種:

      啟動類裝載器,標(biāo)準(zhǔn)擴(kuò)展類裝載器,類路徑裝載器和網(wǎng)絡(luò)類裝載器。

      這4種ClassLoader的優(yōu)先級依次從高到低,使用所謂的“雙親委派模型”。確切地說,如果一個網(wǎng)絡(luò)類裝載器被請求裝載一個java.lang.Integer,它會首先把請求發(fā)送給上一級的類路徑裝載器,如果返回已裝載,則網(wǎng)絡(luò)類裝載器將不會裝載這個java.lang.Integer,如果上一級的類路徑裝載器返回未裝載,它才會裝載java.lang.Integer。

      類似的,類路徑裝載器收到請求后(無論是直接請求裝載還是下一級的ClassLoader上傳的請求),它也會先把請求發(fā)送到上一級的標(biāo)準(zhǔn)擴(kuò)展類裝載器,這樣一層一層上傳,于是啟動類裝載器優(yōu)先級最高,如果它按照自己的方式找到了java.lang.Integer,則下面的ClassLoader 都不能再裝載java.lang.Integer,盡管你自己寫了一個java.lang.Integer,試圖取代核心庫的java.lang.Integer是不可能的,因為自己寫的這個類根本無法被下層的ClassLoader裝載。

      再說說Package權(quán)限。Java語言規(guī)定,在同一個包中的class,如果沒有修飾符,默認(rèn)為Package權(quán)限,包內(nèi)的class都可以訪問。但是這還不夠準(zhǔn)確。確切的說,只有由同一個ClassLoader裝載的class才具有以上的Package權(quán)限。比如啟動類裝載器裝載了java.lang.String,類路徑裝載器裝載了我們自己寫的java.lang.Test,它們不能互相訪問對方具有Package權(quán)限的方法。這樣就阻止了惡意代碼訪問核心類的Package權(quán)限方法。

    主站蜘蛛池模板: 日本一线a视频免费观看| 13小箩利洗澡无码视频网站免费 | 日本黄页网址在线看免费不卡| 真人做A免费观看| 亚洲视屏在线观看| 日本人的色道免费网站| 亚洲日产2021三区| 最近免费中文字幕视频高清在线看| 亚洲国产美女在线观看| 99热在线精品免费全部my| 四虎亚洲精品高清在线观看| 免费av欧美国产在钱| 亚洲精品无码永久在线观看男男| 好吊妞在线成人免费| 国产亚洲综合精品一区二区三区| 亚洲国产成人久久一区WWW| 一区二区免费在线观看| 久久久久久久尹人综合网亚洲| 日韩精品无码免费一区二区三区 | 亚洲不卡中文字幕| 国产香蕉九九久久精品免费| 亚洲AV无码专区亚洲AV桃| 亚洲国产精品不卡毛片a在线| 免费毛片在线看不用播放器| 亚洲精品在线网站| 日本免费福利视频| 成人妇女免费播放久久久| 夜夜亚洲天天久久| 在线观看人成网站深夜免费| 一级一看免费完整版毛片| 亚洲天天在线日亚洲洲精| 免费看国产成年无码AV片| a免费毛片在线播放| 亚洲成在人线中文字幕| 免费在线观看中文字幕| 污污网站18禁在线永久免费观看| 中文字幕在线观看亚洲日韩| 亚洲中文字幕无码一区二区三区| 成人免费在线看片| 久久最新免费视频| 亚洲综合色一区二区三区|