麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學(xué)院 > 開發(fā)設(shè)計 > 正文

關(guān)于getClass().getClassLoader()

2019-11-10 20:41:56
字體:
供稿:網(wǎng)友

InputStream   is   =   getClass().getClassLoader().getResourceAsStream("helloworld.PRoperties");中g(shù)etClass()和getClassLoader()都是什么意思呀.getClass():取得當(dāng)前對象所屬的Class對象  getClassLoader():取得該Class對象的類裝載器類裝載器負(fù)責(zé)從java字符文件將字符流讀入內(nèi)存,并構(gòu)造Class類對象,在你說的問題哪里,通過它可以得到一個文件的輸入流getClass :public final Class getClass()Returns the runtime class of an object. That Class object is the object that is locked by static synchronized methods of the represented class.Returns:the object of type Class that represents the runtime class of the object.

getClassLoaderpublic ClassLoader getClassLoader()Returns the class loader for the class. Some implementations may use null to represent the bootstrap class loader. This method will return null in such implementations if this class was loaded by the bootstrap class loader.If a security manager is present, and the caller′s class loader is not null and the caller′s class loader is not the same as or an ancestor of the class loader for the class whose class loader is requested, then this method calls the security manager′s checkPermission method with a RuntimePermission("getClassLoader") permission to ensure it′s ok to access the class loader for the class.

If this object represents a primitive type or void, null is returned.

Returns:the class loader that loaded the class or interface represented by this object.Throws:SecurityException - if a security manager exists and its checkPermission method denies access to the class loader for the class.See Also:ClassLoader, SecurityManager.checkPermission(java.security.Permission), RuntimePermissionClass.getClassLoader()的一個小陷阱:)昨天我的code總在Integer.class.getClassLoader().getResource("*********");這一句拋出空指針異常,定位為getClassLoader()返回null,查了一下jdk的文檔,原來這里還有一個陷阱:jdk中關(guān)于getClassLoader()的描述:/**     * Returns the class loader for the class. Some implementations may use     * null to represent the bootstrap class loader. This method will return     * null in such implementations if this class was loaded by the bootstrap     * class loader.     *     * <p> If a security manager is present, and the caller's class loader is     * not null and the caller's class loader is not the same as or an ancestor of     * the class loader for the class whose class loader is requested, then     * this method calls the security manager's <code>checkPermission</code>     * method with a <code>RuntimePermission("getClassLoader")</code>     * permission to ensure it's ok to access the class loader for the class.     *     * <p>If this object     * represents a primitive type or void, null is returned......

上面的英文可以用下面的話來理解:

裝載類的過程非常簡單:查找類所在位置,并將找到的Java類的字節(jié)碼裝入內(nèi)存,生成對應(yīng)的Class對象。Java的類裝載器專門用來實(shí)現(xiàn)這樣的過程,JVM并不止有一個類裝載器,事實(shí)上,如果你愿意的話,你可以讓JVM擁有無數(shù)個類裝載器,當(dāng)然這除了測試JVM外,我想不出還有其他的用途。你應(yīng)該已經(jīng)發(fā)現(xiàn)到了這樣一個問題,類裝載器自身也是一個類,它也需要被裝載到內(nèi)存中來,那么這些類裝載器由誰來裝載呢,總得有個根吧?沒錯,確實(shí)存在這樣的根,它就是神龍見首不見尾的Bootstrap ClassLoader. 為什么說它神龍見首不見尾呢,因為你根本無法在Java代碼中抓住哪怕是它的一點(diǎn)點(diǎn)的尾巴,盡管你能時時刻刻體會到它的存在,因為java的運(yùn)行環(huán)境所需要的所有類庫,都由它來裝載,而它本身是C++寫的程序,可以獨(dú)立運(yùn)行,可以說是JVM的運(yùn)行起點(diǎn),偉大吧。在Bootstrap完成它的任務(wù)后,會生成一個AppClassLoader(實(shí)際上之前系統(tǒng)還會使用擴(kuò)展類裝載器ExtClassLoader,它用于裝載Java運(yùn)行環(huán)境擴(kuò)展包中的類),這個類裝載器才是我們經(jīng)常使用的,可以調(diào)用ClassLoader.getSystemClassLoader() 來獲得,我們假定程序中沒有使用類裝載器相關(guān)操作設(shè)定或者自定義新的類裝載器,那么我們編寫的所有java類通通會由它來裝載,值得尊敬吧。AppClassLoader查找類的區(qū)域就是耳熟能詳?shù)腃lasspath,也是初學(xué)者必須跨過的門檻,有沒有靈光一閃的感覺,我們按照它的類查找范圍給它取名為類路徑類裝載器。還是先前假定的情況,當(dāng)Java中出現(xiàn)新的類,AppClassLoader首先在類傳遞給它的父類類裝載器,也就是Extion ClassLoader,詢問它是否能夠裝載該類,如果能,那AppClassLoader就不干這活了,同樣Extion ClassLoader在裝載時,也會先問問它的父類裝載器。我們可以看出類裝載器實(shí)際上是一個樹狀的結(jié)構(gòu)圖,每個類裝載器有自己的父親,類裝載器在裝載類時,總是先讓自己的父類裝載器裝載(多么尊敬長輩),如果父類裝載器無法裝載該類時,自己就會動手裝載,如果它也裝載不了,那么對不起,它會大喊一聲:Exception,class not found。有必要提一句,當(dāng)由直接使用類路徑裝載器裝載類失敗拋出的是NoClassDefFoundException異常。如果使用自定義的類裝載器loadClass方法或者ClassLoader的findSystemClass方法裝載類,如果你不去刻意改變,那么拋出的是ClassNotFoundException。

這里jdk告訴我們:如果一個類是通過bootstrap 載入的,那我們通過這個類去獲得classloader的話,有些jdk的實(shí)現(xiàn)是會返回一個null的,比如說我用 new Object().getClass().getClassLoader()的話,會返回一個null,這樣的話上面的代碼就會出現(xiàn)NullPointer異常.所以保險起見我們最好還是使用我們自己寫的類來獲取classloader("this.getClass().getClassLoader()“),這樣一來就不會有問題。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 国产精品中文在线 | 91久久极品少妇韩国 | 欧美1| 99在线在线视频免费视频观看 | 国产精品区一区二区三区 | 亚洲精品日韩色噜噜久久五月 | 中文字幕免费在线观看视频 | 精品久久久久久久久亚洲 | 亚洲一级电影在线观看 | 欧美韩国日本在线 | 精品亚洲va在线va天堂资源站 | chinesexxxx刘婷hd 国产资源视频在线观看 | 黄在线观看在线播放720p | bt 自拍 另类 综合 欧美 | 在线免费观看毛片视频 | 成人毛片免费视频 | 久久探花 | 九九久久视频 | 伊人午夜| 免费a级黄色片 | 国产精品视频一区二区三区综合 | 免费a级片在线观看 | 奶子吧naiziba.cc免费午夜片在线观看 | 在线免费观看毛片视频 | av在线免费网| av免费在线观看免费 | 中文字幕在线视频日本 | 国产精品一区在线观看 | 一级电影免费看 | 黄色片在线免费播放 | 日韩 欧美 中文 | 欧美成人免费 | 国产精品久久久久久久久久 | 精品一区二区三区免费视频 | 久久激情国产 | 日本在线视频免费观看 | 免费国产在线观看 | 1级黄色毛片 | 国产毛片网站 | 久久国产精品区 | 日韩精品一二三区 |