OSGi和普通java工程中各個classloader的區別

來源:互聯網
上載者:User

OSGI架構下

this.getClass().getClassLoader() =  org.eclipse.osgi.internal.baseadaptor.DefaultClassLoader@186c6b2

Thread.currentThread().getContextClassLoader() = org.eclipse.core.runtime.internal.adaptor.ContextFinder@16b13c7

ClassLoader.getSystemClassLoader() = sun.misc.Launcher$AppClassLoader@19821f

在普通java程式中
this.getClass().getClassLoader() =  sun.misc.Launcher$AppClassLoader@19821f

Thread.currentThread().getContextClassLoader() = sun.misc.Launcher$AppClassLoader@19821f

ClassLoader.getSystemClassLoader() = sun.misc.Launcher$AppClassLoader@19821f

由此我們可以看出,在OSGi架構下,如果動態載入不在本bundle bin目錄下的類的話,只有使用ClassLoader.getSystemClassLoader()。

而且經過實驗發現在OSGi架構下,使用其他兩個class loader載入非bin目錄(本bundle預設類輸出路徑),即使給出絕對路徑,系統也會出現找不到該類的異常。

而且要注意,在OSGi下,編譯的時候this.getClass().getClassLoader() 和Thread.currentThread().getContextClassLoader() 可以像普通java工程一樣賦值給一個urlclassloader,但是在啟動並執行時候會出現不能強制類型轉換的異常。這點分析可知,osgi架構下的this.getClass().getClassLoader() 和Thread.currentThread().getContextClassLoader() 與一般java下的這兩個loader是不一樣的。在以後用的時候還得多加註意。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.