更多完整項目下載。未完待續(xù)。源碼。圖文知識后續(xù)上傳github。
可以點擊關(guān)于我?聯(lián)系我獲取創(chuàng)新互聯(lián)從2013年成立,先為白沙黎族等服務(wù)建站,白沙黎族等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為白沙黎族企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
1.java的運行需要JVM,同樣android中使用了java語言,也需要一個VM。針對手機處理器和內(nèi)存等硬件資源不足而推出來的一款VM,為android運行提供環(huán)境,叫DVM。
2.Dalvik虛擬機允許多個instance的存在。實際上android中的每一個app都是運行在自己VM實例之中(沙盒)。每一個VM實例在linux中又是一個單獨的進(jìn)程,所以可以認(rèn)為是同一個概念。運行在自己的DVM進(jìn)程之中,不同的app不會相互干擾,且不會因為一個DVM的崩潰導(dǎo)致所有的app進(jìn)程都崩潰。這點來說,Android dvm的進(jìn)程和Linux的進(jìn)程, 應(yīng)用程序的進(jìn)程 概念類似。
3.與JVM的區(qū)別:
JVM編譯過程 java->class->jar
DVM編譯過程java->class->dex
總結(jié)dvm與jvm區(qū)別:
區(qū)別一:dvm執(zhí)行的是.dex格式文件 jvm執(zhí)行的是.class文件 android程序編譯完之后生產(chǎn).class文件,然后,dex工具會把.class文件處理成.dex文件,然后把資源文件和.dex文件等打包成.apk文件。apk就是android package的意思。 jvm執(zhí)行的是.class文件。
區(qū)別二:dvm是基于寄存器的虛擬機 而jvm執(zhí)行是基于虛擬棧的虛擬機。寄存器存取速度比??斓亩啵琩vm可以根據(jù)硬件實現(xiàn)最大的優(yōu)化,比較適合移動設(shè)備。
區(qū)別三:.class文件存在很多的冗余信息,dex工具會去除冗余信息,并把所有的.class文件整合到.dex文件中。減少了I/O操作,提高了類的查找速度
一張圖了解dvm主要做的事:
//AndroidRuntime.cpp
int AndroidRuntime::startVm(JavaVM** pJavaVM, JNIEnv** pEnv, bool zygote)
{
JavaVMInitArgs initArgs;
char propBuf[PROPERTY_VALUE_MAX];
char stackTraceFileBuf[sizeof("-Xstacktracefile:")-1 + PROPERTY_VALUE_MAX];
char jniOptsBuf[sizeof("-Xjniopts:")-1 + PROPERTY_VALUE_MAX];
char heapstartsizeOptsBuf[sizeof("-Xms")-1 + PROPERTY_VALUE_MAX];
char heapsizeOptsBuf[sizeof("-Xmx")-1 + PROPERTY_VALUE_MAX];
char heapgrowthlimitOptsBuf[sizeof("-XX:HeapGrowthLimit=")-1 + PROPERTY_VALUE_MAX];
char heapminfreeOptsBuf[sizeof("-XX:HeapMinFree=")-1 + PROPERTY_VALUE_MAX];
char heapmaxfreeOptsBuf[sizeof("-XX:HeapMaxFree=")-1 + PROPERTY_VALUE_MAX];
char usejitOptsBuf[sizeof("-Xusejit:")-1 + PROPERTY_VALUE_MAX];
char jitmaxsizeOptsBuf[sizeof("-Xjitmaxsize:")-1 + PROPERTY_VALUE_MAX];
char jitinitialsizeOptsBuf[sizeof("-Xjitinitialsize:")-1 + PROPERTY_VALUE_MAX];
char jitthresholdOptsBuf[sizeof("-Xjitthreshold:")-1 + PROPERTY_VALUE_MAX];
char useJitProfilesOptsBuf[sizeof("-Xjitsaveprofilinginfo:")-1 + PROPERTY_VALUE_MAX];
char jitprithreadweightOptBuf[sizeof("-Xjitprithreadweight:")-1 + PROPERTY_VALUE_MAX];
char jittransitionweightOptBuf[sizeof("-Xjittransitionweight:")-1 + PROPERTY_VALUE_MAX];
char gctypeOptsBuf[sizeof("-Xgc:")-1 + PROPERTY_VALUE_MAX];
char backgroundgcOptsBuf[sizeof("-XX:BackgroundGC=")-1 + PROPERTY_VALUE_MAX];
char heaptargetutilizationOptsBuf[sizeof("-XX:HeapTargetUtilization=")-1 + PROPERTY_VALUE_MAX];
char cachePruneBuf[sizeof("-Xzygote-max-boot-retry=")-1 + PROPERTY_VALUE_MAX];
char dex2oatXmsImageFlagsBuf[sizeof("-Xms")-1 + PROPERTY_VALUE_MAX];
char dex2oatXmxImageFlagsBuf[sizeof("-Xmx")-1 + PROPERTY_VALUE_MAX];
char dex2oatXmsFlagsBuf[sizeof("-Xms")-1 + PROPERTY_VALUE_MAX];
char dex2oatXmxFlagsBuf[sizeof("-Xmx")-1 + PROPERTY_VALUE_MAX];
char dex2oatCompilerFilterBuf[sizeof("--compiler-filter=")-1 + PROPERTY_VALUE_MAX];
char dex2oatImageCompilerFilterBuf[sizeof("--compiler-filter=")-1 + PROPERTY_VALUE_MAX];
char dex2oatThreadsBuf[sizeof("-j")-1 + PROPERTY_VALUE_MAX];
char dex2oatThreadsImageBuf[sizeof("-j")-1 + PROPERTY_VALUE_MAX];
char dex2oat_isa_variant_key[PROPERTY_KEY_MAX];
char dex2oat_isa_variant[sizeof("--instruction-set-variant=") -1 + PROPERTY_VALUE_MAX];
char dex2oat_isa_features_key[PROPERTY_KEY_MAX];
char dex2oat_isa_features[sizeof("--instruction-set-features=") -1 + PROPERTY_VALUE_MAX];
char dex2oatFlagsBuf[PROPERTY_VALUE_MAX];
char dex2oatImageFlagsBuf[PROPERTY_VALUE_MAX];
char extraOptsBuf[PROPERTY_VALUE_MAX];
char voldDecryptBuf[PROPERTY_VALUE_MAX];
...
/*
* Initialize the VM.
*
* The JavaVM* is essentially per-process, and the JNIEnv* is per-thread.
* If this call succeeds, the VM is ready, and we can start issuing
* JNI calls.
*/
if (JNI_CreateJavaVM(pJavaVM, pEnv, &initArgs) < 0) {
ALOGE("JNI_CreateJavaVM failed\n");
return -1;
}
return 0;
}
void AndroidRuntime::start(const char* className, const Vector& options, bool zygote)
{
/* start the virtual machine */
JniInvocation jni_invocation;
jni_invocation.Init(NULL);
JNIEnv* env;
if (startVm(&mJavaVM, &env, zygote) != 0) {
return;
}
onVmCreated(env);
/*
* Register android functions.
*/
if (startReg(env) < 0) {
ALOGE("Unable to register all android natives\n");
return;
}
}
//Dalvik虛擬機在Zygote進(jìn)程中的啟動過程,這個啟動過程主要就是完成了以下四個事情:
//1. 創(chuàng)建了一個Dalvik虛擬機實例;
//2. 加載了Java核心類及其JNI方法;
//3. 為主線程的設(shè)置了一個JNI環(huán)境;
//4. 注冊了Android核心類的JNI方法。
Zygote 啟動Dalvik作用:
2.Java核心類和Android核心類(位于dex文件中),以及它們的JNI方法(位于so文件中),都是以內(nèi)存映射的方式來讀取的,因此,Zygote進(jìn)程在創(chuàng)建Android應(yīng)用程序進(jìn)程的時候,除了可以將自身的Dalvik虛擬機實例復(fù)制到新創(chuàng)建的Android應(yīng)用程序進(jìn)程之外,還可以與新創(chuàng)建的Android應(yīng)用程序進(jìn)程共享Java核心類和Android核心類,以及它們的JNI方法,這樣就可以節(jié)省內(nèi)存消耗。
更多完整項目下載。未完待續(xù)。源碼。圖文知識后續(xù)上傳github。
可以點擊關(guān)于我?聯(lián)系我獲取