Zygote Service分析

本文详细介绍了Android系统中Zygote机制的工作原理,包括其架构、核心组件Zygote.java、ZygoteConnection.java和ZygoteInit.java的作用,以及如何通过fork机制高效创建进程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从大的架构上讲,Zygote 是一个简单的典型C/S 结构。其他进程作为一个客服端向Zygote 发出”孵化”请求,Zygote 接收到命令就“孵化”出一个Activity 进程来。


Zygote系统代码组成及其调用结构:
Zygote.java
提供访问Dalvik “zygote”的接口。主要是包装Linux系统的Fork,以建立一个新的VM 实例进程。
ZygoteConnection.java
Zygote的套接口连接管理及其参数解析。其他Actvitiy 建立进程请求是通过套接口发送命令参数给Zygote。
ZygoteInit.java
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 使用了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 的实际映射状态。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值