您好,登錄后才能下訂單哦!
Java中類加載器的特點有哪些,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
Java類加載器的特性:
每個ClassLoader都維護了一份自己的名稱空間, 同一個名稱空間里不能出現兩個同名的類。
為了實現java安全沙箱模型頂層的類加載器安全機制, java默認采用了 " 雙親委派的加載鏈 " 結構。
類圖中, BootstrapClassLoader是一個單獨的java類, 其實在這里, 不應該叫他是一個java類。因為,它已經完全不用java實現了。它是在jvm啟動時, 就被構造起來的, 負責java平臺核心庫。
自定義類加載器加載一個類的步驟
ClassLoader 類加載邏輯分析, 以下邏輯是除 BootstrapClassLoader 外的類加載器加載流程:
// 檢查類是否已被裝載過 Class c = findLoadedClass(name); if (c == null ) { // 指定類未被裝載過 try { if (parent != null ) { // 如果父類加載器不為空, 則委派給父類加載 c = parent.loadClass(name, false ); } else { // 如果父類加載器為空, 則委派給啟動類加載加載 c = findBootstrapClass0(name); } } catch (ClassNotFoundException e) { // 啟動類加載器或父類加載器拋出異常后, 當前類加載器將其 // 捕獲, 并通過findClass方法, 由自身加載 c = findClass(name); } }
線程上下文類加載器
java默認的線程上下文類加載器是 系統類加載器(AppClassLoader)。
//Now create the class loader to use to launch the application try { loader = AppClassLoader.getAppClassLoader(extcl); } catch(IOException e) { throw new InternalError( "Could not create application class loader" ); } //Also set the context class loader for the primordial thread. Thread.currentThread().setContextClassLoader(loader);
Java代碼
//Now create the class loader to use to launch the application try { loader = AppClassLoader.getAppClassLoader(extcl); } catch (IOException e) { throw new InternalError( "Could not create application class loader" ); } //Also set the context class loader for the primordial thread. Thread.currentThread().setContextClassLoader(loader);
以上代碼摘自sun.misc.Launch的無參構造函數Launch()。使用線程上下文類加載器, 可以在執行線程中, 拋棄雙親委派加載鏈模式, 使用線程上下文里的類加載器加載類.典型的例子有, 通過Java類加載器上下文來加載第三方庫jndi實現, 而不依賴于雙親委派.大部分java app服務器(jboss, tomcat..)也是采用contextClassLoader來處理web服務。還有一些采用 hotswap 特性的框架, 也使用了線程上下文類加載器, 比如 seasar (full stack framework in japenese).
在Java類中靈活使用Static關鍵字
Netbeans調試跟蹤Java類庫代碼的方法
如何將Jython類型轉換為Java類型
Scala的類層級:與Java類之異同
Java類中熱替換的概念、設計與實現
線程上下文從根本解決了一般應用不能違背雙親委派模式的問題.使java類加載體系顯得更靈活.隨著多核時代的來臨, 相信多線程開發將會越來越多地進入程序員的實際編碼過程中. 因此,在編寫基礎設施時, 通過使用線程上下文來加載類, 應該是一個很好的選擇。當然, 好東西都有利弊. 使用線程上下文加載類, 也要注意, 保證多根需要通信的線程間的類加載器應該是同一個,防止因為不同的類加載器, 導致類型轉換異常(ClassCastException)。
為什么要使用這種雙親委托模式呢?
因為這樣可以避免重復加載,當父親已經加載了該類的時候,就沒有必要子ClassLoader再加載一次。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。