java類加載器(二)

from URL: http://developer.51cto.com/art/201003/189102.htm

 

 

Java 類加載器一個我們經常使用的優秀語言,但是在我們使用的過程中有不少的問題需要我們解決。下面我們就詳細的來看看相關問題的解決方法。想大家有所收穫。

Java類加載器的特性:

每個ClassLoader都維護了一份自己的名稱空間, 同一個名稱空間裏不能出現兩個同名的類。

爲了實現java安全沙箱模型頂層的類加載器安全機制, java默認採用了 " 雙親委派的加載鏈 " 結構。

類圖中, BootstrapClassLoader是一個單獨的java類, 其實在這裏, 不應該叫他是一個java類。因爲,它已經完全不用java實現了。它是在jvm啓動時, 就被構造起來的, 負責java平臺核心庫。

自定義類加載器加載一個類的步驟

ClassLoader 類加載邏輯分析, 以下邏輯是除 BootstrapClassLoader 外的類加載器加載流程:


線程上下文類加載器

java默認的線程上下文類加載器是 系統類加載器(AppClassLoader)

Java代碼


以上代碼摘自sun.misc.Launch的無參構造函數Launch()。使用線程上下文類加載器, 可以在執行線程中, 拋棄雙親委派加載鏈模式, 使用線程上下文裏的類加載器加載類.典型的例子有, 通過Java類加載器上下文來加載第三方庫jndi實現, 而不依賴於雙親委派.大部分java app服務器(jboss, tomcat..)也是採用contextClassLoader來處理web服務。還有一些採用 hotswap 特性的框架, 也使用了線程上下文類加載器, 比如 seasar (full stack framework in japenese).

線程上下文從根本解決了一般應用不能違背雙親委派模式的問題.使java類加載體系顯得更靈活.隨着多核時代的來臨, 相信多線程開發將會越來越多地進入程序員的實際編碼過程中. 因此,在編寫基礎設施時, 通過使用線程上下文來加載類, 應該是一個很好的選擇。當然, 好東西都有利弊. 使用線程上下文加載類, 也要注意, 保證多根需要通信的線程間的類加載器應該是同一個,防止因爲不同的類加載器, 導致類型轉換異常(ClassCastException)。

爲什麼要使用這種雙親委託模式呢?

因爲這樣可以避免重複加載,當父親已經加載了該類的時候,就沒有必要子ClassLoader再加載一次。以上就是對Java類加載器的詳細介紹。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章