資源描述:
《JVM加載機(jī)制2》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫(kù)。
1、JVM加載class文件的原理機(jī)制1.Java中的所有類(lèi),必須被裝載到j(luò)vm中才能運(yùn)行,這個(gè)裝載工作是由jvm中的類(lèi)裝載器完成的,?類(lèi)裝載器所做的工作實(shí)質(zhì)是把類(lèi)文件從硬盤(pán)讀取到內(nèi)存中2.java中的類(lèi)大致分為三種:????1.系統(tǒng)類(lèi)????2.擴(kuò)展類(lèi)????3.由程序員自定義的類(lèi)3.類(lèi)裝載方式,有兩種????1.隱式裝載,程序在運(yùn)行過(guò)程中當(dāng)碰到通過(guò)new等方式生成對(duì)象時(shí),隱式調(diào)用類(lèi)裝載器加載對(duì)應(yīng)的類(lèi)到j(luò)vm中,????2.顯式裝載,通過(guò)class.forname()等方法,顯式加載需要的類(lèi)??隱式加載與顯式加載的區(qū)別:????兩者
2、本質(zhì)是一樣4.類(lèi)加載的動(dòng)態(tài)性體現(xiàn)????一個(gè)應(yīng)用程序總是由n多個(gè)類(lèi)組成,Java程序啟動(dòng)時(shí),并不是一次把所有的類(lèi)全部加載后再?運(yùn)行,它總是先把保證程序運(yùn)行的基礎(chǔ)類(lèi)一次性加載到j(luò)vm中,其它類(lèi)等到j(luò)vm用到的時(shí)候再加載,這樣的好處是節(jié)省了內(nèi)存的開(kāi)銷(xiāo),因?yàn)閖ava最早就是為嵌入式系統(tǒng)而設(shè)計(jì)的,內(nèi)存寶貴,這是一種可以理解的機(jī)制,而用到時(shí)再加載這也是java動(dòng)態(tài)性的一種體現(xiàn)5.java類(lèi)裝載器????Java中的類(lèi)裝載器實(shí)質(zhì)上也是類(lèi),功能是把類(lèi)載入jvm中,值得注意的是jvm的類(lèi)裝載器并不是一個(gè),而是三個(gè),層次結(jié)構(gòu)如下:??????Boo
3、tstrapLoader?-負(fù)責(zé)加載系統(tǒng)類(lèi)????????????
4、??????????--ExtClassLoader?-負(fù)責(zé)加載擴(kuò)展類(lèi)??????????????????????????
5、??????????????????????--AppClassLoader?-負(fù)責(zé)加載應(yīng)用類(lèi)????????為什么要有三個(gè)類(lèi)加載器,一方面是分工,各自負(fù)責(zé)各自的區(qū)塊,另一方面為了實(shí)現(xiàn)委托模型,下面會(huì)談到該模型6.類(lèi)加載器之間是如何協(xié)調(diào)工作的??????前面說(shuō)了,java中有三個(gè)類(lèi)加載器,問(wèn)題就來(lái)了,碰到一個(gè)類(lèi)需要加載時(shí),它們之間是如何協(xié)調(diào)工
6、作的,即java是如何區(qū)分一個(gè)類(lèi)該由哪個(gè)類(lèi)加載器來(lái)完成呢。?在這里java采用了委托模型機(jī)制,這個(gè)機(jī)制簡(jiǎn)單來(lái)講,就是“類(lèi)裝載器有載入類(lèi)的需求時(shí),會(huì)先請(qǐng)示其Parent使用其搜索路徑幫忙載入,如果Parent找不到,那么才由自己依照自己的搜索路徑搜索類(lèi)”,注意喔,這句話具有遞歸性?下面舉一個(gè)例子來(lái)說(shuō)明,為了更好的理解,先弄清楚幾行代碼:?PublicclassTest{????Publicstaticvoidmain(String[]arg){??????ClassLoaderc?=Test.class.getClassLoader
7、();?//獲取Test類(lèi)的類(lèi)加載器????????System.out.println(c);???????ClassLoaderc1=c.getParent();?//獲取c這個(gè)類(lèi)加載器的父類(lèi)加載器????????System.out.println(c1);??????ClassLoaderc2=c1.getParent();//獲取c1這個(gè)類(lèi)加載器的父類(lèi)加載器????????System.out.println(c2);??}?}?把以上代碼存到d:my文件夾下,直接編譯,然后在dos模式下運(yùn)行?D:myjavaTe
8、st????。。。AppClassLoader。。。????。。。ExtClassLoader。。。????NullD:my注:。。。表示省略了內(nèi)容?可以看出Test是由AppClassLoader加載器加載的?AppClassLoader的Parent加載器是ExtClassLoader但是ExtClassLoader的Parent為null是怎么回事呵,朋友們留意的話,前面有提到BootstrapLoader是用C++語(yǔ)言寫(xiě)的,依java的觀點(diǎn)來(lái)看,邏輯上并不存在BootstrapLoader的類(lèi)實(shí)體,所以在java程序代碼
9、里試圖打印出其內(nèi)容時(shí),我們就會(huì)看到輸出為null?【注:以下內(nèi)容大部分引用java深度歷險(xiǎn)】?弄明白了上面的示例,接下來(lái)直接進(jìn)入類(lèi)裝載的委托模型實(shí)例,寫(xiě)兩個(gè)文件,如下:?文件:Test1.java?PublicclassTest1{????Publicstaticvoidmain(String[]arg){????????System.out.println(Test1.class.getClassLoader());????????Test2t2=newTest2();????????T2.print();??}?}文件:Tes
10、t2.java?PublicclassTest2{????Publicvoidprin(){????????System.out.println(this.getClass().getClassLoader());????}?}這兩個(gè)類(lèi)的作用就是打