隱式方法:new 顯式方法:1。java.lang.Class的forName方法2。java.lang.ClassLoader里的loadClass方法◆ 無(wú)法自行產(chǎn)生Class的實(shí)體,因?yàn)闃?gòu)造函數(shù)聲明為private。◇ 只能通過(guò)Object的getClass方法,或者Class.forName("類名")獲得。◆ Class類的實(shí)體在第一次載入內(nèi)存時(shí)就建立了。以后在程序中產(chǎn)生Class代表的類的實(shí)體,其內(nèi)部都會(huì)有個(gè)字段記錄著這個(gè)Class類所在的位置。◇ 可以把每個(gè)Class類的實(shí)體當(dāng)作是某個(gè)類(*.class)在內(nèi)存中的代理。◆ 在Java中,每個(gè)類都是由某個(gè)類加載器(ClassLoader)來(lái)載入的,因此在Class類的實(shí)體中,由字段記錄載入它的ClassLoader的實(shí)體。如果該字段是null,不代表它不是由類裝載器所載入,而是代表這個(gè)類由引導(dǎo)式裝載器(bootstrap loader)載入。但是這個(gè)裝載器不是java編寫的,所以沒有實(shí)體。 圖1注意:系統(tǒng)里同時(shí)存在多個(gè)ClassLoader實(shí)體。而且一個(gè)類裝載器可以載入多個(gè)類★ 使用已有類裝載器
注意:loadClass方法加載類時(shí)不會(huì)自動(dòng)調(diào)用靜態(tài)初始化塊(static塊),必須等到第一次實(shí)體化該類時(shí),才會(huì)調(diào)用。這與forName時(shí)傳入第二個(gè)參數(shù)為false的效果相同。下面是上述代碼的另一種寫法:
★ 自己建立類裝載器來(lái)載入類URLClassLoader★ 類裝載器的階層體系Java程序運(yùn)行流程:shur輸入java ***.class,java.exe根據(jù)自己的搜索邏輯找到JRE,接著找到位于JRE中的jvm.dll(真正的java虛擬機(jī))。最后載入這個(gè)動(dòng)態(tài)鏈接庫(kù),激活java虛擬機(jī)。 虛擬機(jī)一旦激活,會(huì)先做一些初始化操作,如獲取系統(tǒng)參數(shù)。 初始化完成后,產(chǎn)生第一個(gè)類裝載器 Bootstrap Loader。然后做一些基本的初始化,然后它載入sun.misc命名空間底下的Launcher.java之中的ExtClassLoader,并設(shè)置其parent為null。然后Bootstrap Loader會(huì)繼續(xù)載入sun.misc命名空間下的Launcher.java之中的AppClassLoader,并設(shè)置其parent為剛載入的ExtClassLoader實(shí)體。 最后由AppClassLoader負(fù)責(zé)載入***.class。 注意:上述三個(gè)類裝載器搜索類的路徑都是載入時(shí)讀取的,分別是“sun.boot.class.path”、“java.ext.dirs”、“java.class.path”,而且在虛擬機(jī)中只保留一份。在系統(tǒng)運(yùn)行過(guò)程中不可能動(dòng)態(tài)改變,除非使用新的類裝載器。★ 委托模型 類裝載器有載入類的需求時(shí),會(huì)先請(qǐng)示其Parent使用其搜索路徑幫忙載入。如果Parent找不到,才由自己依照自己的搜索路徑搜索類。
Powered by: BlogJava Copyright © 呆呆向前沖的blog