在本章我們會接觸到這兩個單詞:
通過這兩個單詞,我們就可以大體知道Zygote是干什麼的了,就是叫老母雞下蛋。通過“Zygote”產出不同的子“Zygote”。從大的架構上講,Zygote是一個簡單的典型C/S結構。其他進程作為一個客服端向Zygote發出”孵化”請求,Zygote接收到命令就“孵化”出一個Activity進程來。
Zygote系統代碼組成及其調用結構:
提供訪問Dalvik “zygote”的接口。主要是包裝Linux系統的Fork,以建立一個新的VM實例進程。
Zygote的套接口連接管理及其參數解析。其他Actvitiy建立進程請求是通過套接口發送命令參數給Zygote。
Zygote的main函數入口。
Zygote系統代碼層次調用
main()
startSystemServer()…
runSelectLoopMode()
Accept socket connection
Conntecion.RunOnce()
Read argument
folkAndSpecialize
folkAndSpecialize使用Native函數Dalvik_dalvik_system_Zygote_forkAndSpecialize
//native 的獲取
dalvik/vm/native
//dalvik_system_Zygote.c
const DalvikNativeMethod dvm_dalvik_system_Zygote[] = {
{ "fork", "()I",
Dalvik_dalvik_system_Zygote_fork },
{ "forkAndSpecialize", "(II[II[[I)I",
Dalvik_dalvik_system_Zygote_forkAndSpecialize },
{ "forkSystemServer", "(II[II[[I)I",
Dalvik_dalvik_system_Zygote_forkSystemServer },
{ NULL, NULL, NULL },
};
在這裡我們就有了Zygote服務的全貌理解,也在Code中印證了。{由於Android中沒有具體應用程序的入口,都是通過啟動Actvity來啟動相關的Android應用,而這個 Android應用則對應著Linux進程,Activity便Host在這個應用程序上。},{Activity在本質上是個什麼東西,就是一個Linux進程}
從分析中我們可以看到,Android使用了Linux的fork機制。在Linux中Fork是很高效的。
一個Android的應用實際上一個Linux進程,所謂進程具備下面幾個要素,
a.要有一段程序供該進程運行,程序是可以被多個進程共享的。
b..進程專用的系統堆棧空間。
c.進程控制塊,在linux中具體實現是task_struct
d.有獨立的存儲空間。
fork 創造的子進程復制了父親進程的資源,包括內存的內容task_struct內容,在復制過程中,子進程復制了父進程的task_struct,系統堆棧空間和頁面表,而當子進程改變了父進程的變量時候,會通過copy_on_write的手段為所涉及的頁面建立一個新的副本。所以只有子進程有改變變量時,子進程才新建了一個頁面復制原來頁面的內容,基本資源的復制是必須的,整體看上去就像是父進程的獨立存儲空間也復制了一遍。
再看看下面Google在講解Dalvik虛擬機的圖片,我們就大體有了Android系統中Actvitiy的實際映射狀態有了基本的認識。