Java的ClassLoader就是用來動(dòng)態(tài)裝載class的,ClassLoader對(duì)一個(gè)class只會(huì)裝載一次,JVM使用的ClassLoader一共有4種:
啟動(dòng)類裝載器,標(biāo)準(zhǔn)擴(kuò)展類裝載器,類路徑裝載器和網(wǎng)絡(luò)類裝載器。
這
4種ClassLoader的優(yōu)先級(jí)依次從高到低,使用所謂的“雙親委派模型”。
初秋日本街拍發(fā)型確切地說,如果一個(gè)網(wǎng)絡(luò)類裝載器被請(qǐng)求裝載一個(gè)
java.lang.Integer,它會(huì)首先把請(qǐng)求發(fā)送給上一級(jí)的類路徑裝載器,如果返回已裝載,則網(wǎng)絡(luò)類裝載器將不會(huì)裝載這個(gè)
java.lang.Integer,如果上一級(jí)的類路徑裝載器返回未裝載,它才會(huì)裝載java.lang.Integer。
類似的,類
路徑裝載器收到請(qǐng)求后(無論是直接請(qǐng)求裝載還是下一級(jí)的ClassLoader上傳的請(qǐng)求),它也會(huì)先把請(qǐng)求發(fā)送到上一級(jí)的標(biāo)準(zhǔn)擴(kuò)展類裝載器,這樣一層一
層上傳,于是啟動(dòng)類裝載器優(yōu)先級(jí)最高,如果它按照自己的方式找到了java.lang.Integer,則下面的ClassLoader都不能再裝載
java.lang.Integer,盡管你自己寫了一個(gè)java.lang.Integer,試圖取代核心庫(kù)的java.lang.Integer是不
可能的,因?yàn)樽约簩懙倪@個(gè)類根本無法被下層的ClassLoader裝載。
再說說Package權(quán)限。Java語(yǔ)言規(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,它們不能互相訪問對(duì)方具有Package權(quán)限的方法。這樣就阻止了惡意代碼訪問核心類的Package權(quán)限方法。
-----------------
JVM
本身包含了一個(gè)ClassLoader稱為Bootstrap ClassLoader,和JVM一樣,Bootstrap
ClassLoader是用本地代碼實(shí)現(xiàn)的,它負(fù)責(zé)加載核心Java
Class(即所有java.*開頭的類)。另外JVM還會(huì)提供兩個(gè)ClassLoader,它們都是用Java語(yǔ)言編寫的,由Bootstrap
ClassLoader加載;其中Extension ClassLoader負(fù)責(zé)加載擴(kuò)展的Java
class(例如所有javax.*開頭的類和存放在JRE的ext目錄下的類),Application
ClassLoader負(fù)責(zé)加載應(yīng)用程序自身的類。
posted on 2010-10-31 19:37
墻頭草 閱讀(1410)
評(píng)論(0) 編輯 收藏