啟動(dòng)類裝載器,標(biāo)準(zhǔn)擴(kuò)展類裝載器,類路徑裝載器和網(wǎng)絡(luò)類裝載器。
這4種ClassLoader的優(yōu)先級(jí)依次從高到低,使用所謂的“雙親委派模型”。確切地說,如果一個(gè)網(wǎng)絡(luò)類裝載器被請求裝載一個(gè)java.lang.Integer,它會(huì)首先把請求發(fā)送給上一級(jí)的類路徑裝載器,如果返回已裝載,則網(wǎng)絡(luò)類裝載器將不會(huì)裝載這個(gè)java.lang.Integer,如果上一級(jí)的類路徑裝載器返回未裝載,它才會(huì)裝載java.lang.Integer。
再說說Package權(quán)限。Java語言規(guī)定,在同一個(gè)包中的class,如果沒有修飾符,默認(rèn)為Package權(quán)限,包內(nèi)的class都可以訪問。但是這還不夠準(zhǔn)確。確切的說,只有由同一個(gè)ClassLoader裝載的class才具有以上的Package權(quán)限。比如啟動(dòng)類裝載器裝載了java.lang.String,類路徑裝載器裝載了我們自己寫的java.lang.Test,它們不能互相訪問對方具有Package權(quán)限的方法。這樣就阻止了惡意代碼訪問核心類的Package權(quán)限方法。
現(xiàn)在來通過擴(kuò)展ClassLoader類實(shí)現(xiàn)一個(gè)自己的類裝載器,每個(gè)Class對象都有一個(gè)引用指向裝載他的ClassLoader,可以通過public ClassLoader getClassLoader()方法得到它。為了創(chuàng)建自己的類裝載器我們應(yīng)該擴(kuò)展ClassLoader類,這是一個(gè)抽象類。假設(shè)要從本地文件系統(tǒng)使用我們實(shí)現(xiàn)的類裝載器裝載一個(gè)類,創(chuàng)建一個(gè)FileClassLoader extends ClassLoader,需要覆蓋ClassLoader中的findClass(String name)方法,這個(gè)方法通過類的名字而得到一個(gè)Class對象。





























































現(xiàn)在把HelloWorld.java放到默認(rèn)包下,然后編譯,把HelloWorld.class放到D:\盤根目錄下,運(yùn)行FileClassLoader類,控制臺(tái)輸出:


Hope you work hard more and more.
Though I am a newcomer to java,but i love java,love my wife....
sun.misc.Launcher$AppClassLoader@82ba41
你這樣并沒有證明調(diào)用了你自己寫的findclass方法,很明顯,加載HelloWorld的是AppClassLoader不是你寫的loader。
麻煩你下次經(jīng)過測試以后再拿出來吧,你這樣可能會(huì)耽誤別人很多的時(shí)間的。
不好意思,我被錯(cuò)誤的引導(dǎo)太多了。
HelloWorld
classloader.FileClassLoader@757aef