本篇文章給大家分享的是有關怎么在Android中利用ClassLoader對類進行加載,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
Java的類加載設計了一套雙親代理的模式,使得用戶沒法替換系統(tǒng)的核心類,從而讓應用更安全。所謂雙親代理就是指,當加載類的時候首先去Bootstrap中加載類,如果沒有則去Extension中加載,如果再沒有才去AppClassLoader中去加載。從而實現(xiàn)安全和穩(wěn)定。
Java ClassLoader
BootstrapClassLoader
引導類加載器 ,用來加載Java的核心庫。通過底層代碼來實現(xiàn)的,基本上只要parent為null,那就表示引導類加載器。
比如:charsets.jar、deploy.jar、javaws.jar、jce.jar、jfr.jar、jfxswt.jar、jsse.jar、management-agent.jar、plugin.jar、resources.jar、rt.jar
ExtClassLoader
拓展類加載器 ,用來加載Java的拓展的類庫, ${JAVA_HOME}/jre/lib/ext/ 目錄中的所有jar。
比如:cldrdata.jar、dnsns.jar、jfxrt.jar、localedata.jar、nashorn.jar、sunec.jar、sunjce_provider.jar、sunpkcs11.jar、zipfs.jar等等
AppClassLoader
系統(tǒng)類加載器 (不要被名字給迷惑),用來加載Java應用中的類。一般來說自己寫的類都是通過這個加載的。而Java中 ClassLoader.getSystemClassLoader() 返回的就是AppClassLoader。(Android中修改了ClassLoader的邏輯,返回的會是一個PathClassLoader)
自定義ClassLoader
用戶如果想自定義ClassLoader的話,只需要繼承自 java.lang.ClassLoader 即可。
ClassLoader中與加載類相關的方法:
也許你不太了解上面幾個函數(shù)的區(qū)別,沒關系,我們來看下源碼是如何實現(xiàn)的。
//ClassLoader.java protected Class<?> loadClass(String name, boolean resolve) throws ClassNotFoundException { // First, check if the class has already been loaded Class c = findLoadedClass(name); if (c == null) { long t0 = System.nanoTime(); try { if (parent != null) { c = parent.loadClass(name, false); } else { c = findBootstrapClassOrNull(name); } } catch (ClassNotFoundException e) { // ClassNotFoundException thrown if class not found // from the non-null parent class loader } if (c == null) { // If still not found, then invoke findClass in order // to find the class. long t1 = System.nanoTime(); c = findClass(name); // this is the defining class loader; record the stats } } return c; }