Android开发之Java基础JVM和ClassLoader以及类加机制面试题
在面試中被問到Java相關(guān)的東西非常多:
首先說下Java內(nèi)存模型:
主要由:
程序計(jì)數(shù)器,Java虛擬機(jī)棧,本地方法棧=>被線程私有
方法區(qū) 堆組成=>被線程共有
Java類加載機(jī)制ClassLoader
主要分為:啟動(dòng)類加載器(C,C++編寫的),系統(tǒng)類加載器,擴(kuò)展類加載器(也可以自定義加載器)
在Java中class字節(jié)碼文件什么時(shí)候被JVM加載進(jìn)內(nèi)存呢?
分為兩種情況,1,當(dāng)調(diào)用類構(gòu)造器 2.調(diào)用類中的靜態(tài)變量或者靜態(tài)方法
在Java中JVM默認(rèn)的加載機(jī)制叫做雙親委派機(jī)制是Java推薦的機(jī)制,并不是強(qiáng)制的機(jī)制,如果我們需要打破這種加載機(jī)制可以自定義類加載器,重寫loadClass方法即可。
什么是雙親委派機(jī)制呢?
當(dāng)類加載器收到加載類或者資源請(qǐng)求時(shí),通常來說首先會(huì)委托給自己的父類去加載,只有當(dāng)父類找不到指定類或者資源時(shí),才會(huì)執(zhí)行自身的類加載過程就叫做雙親委派機(jī)制。
?
Java垃圾回收機(jī)制:
在Java垃圾回收中主要有一種叫做可達(dá)性分析,首先以GCRoot為根節(jié)點(diǎn)向下查找,能被GCRoot直接或間接引用到的對(duì)象為可用對(duì)象,相反不能被GCRoot直接或間接引用到的對(duì)象會(huì)被Java虛擬機(jī)當(dāng)作垃圾在不確定的時(shí)間被回收掉。
問題:那些對(duì)象可以作為GCRoot?
1.Java虛擬機(jī)棧中引用的對(duì)象
2.方法區(qū)中靜態(tài)引用的對(duì)象
3.仍處于存活中的線程對(duì)象
4.Native方法中引用的JNI對(duì)象
?
Java垃圾回收算法:
1.標(biāo)記清除算法 優(yōu)點(diǎn):實(shí)現(xiàn)簡(jiǎn)單不需要將對(duì)象進(jìn)行移動(dòng) 缺點(diǎn):需要中斷進(jìn)程內(nèi)其它組件的執(zhí)行
第一步標(biāo)記mark,第二步清除swipe
首先以GCRoot為根節(jié)點(diǎn)向下查找不能直接俄或間接被GCRoot引用到的對(duì)象會(huì)被標(biāo)記視并且為垃圾被GC在不確定的時(shí)間被回收
2.復(fù)制算法? 優(yōu)點(diǎn):按照順序分配內(nèi)存空間即可,實(shí)現(xiàn)簡(jiǎn)單運(yùn)行高效不用考慮內(nèi)存碎片? 缺點(diǎn):可用內(nèi)存大小為原來的一半,對(duì)象存活率高時(shí)會(huì)頻繁進(jìn)行復(fù)制
將現(xiàn)有空間分為兩塊,每次之使用其中的一塊,在垃圾回收時(shí)將正在使用中的內(nèi)存中存活的對(duì)象復(fù)制到未被使用的內(nèi)存塊中,之后清除正在使用的內(nèi)存塊中的所有對(duì)象,交換兩個(gè)內(nèi)存的角色完成垃圾回收
?
總結(jié)
以上是生活随笔為你收集整理的Android开发之Java基础JVM和ClassLoader以及类加机制面试题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 王者荣耀信誉积分110怎么得(如何玩好《
- 下一篇: android sina oauth2.