zygote在android系统中扮演着关键的角色,主要有以下两个主要功能:
启动SystemServer和孵化应用进程:Zygote是Android中大多数应用进程和系统进程的创建者。它通过fork操作来生成新进程。Zygote为这些新进程提供了基础资源,包括:
常用类:包含Android的Java类库,大部分来自Apache Harmony,这是开源的Java API实现,如java.lang、java.util、java.net等。JNI函数:用于Java和本地代码之间的交互。主题资源:例如主题图片,这些资源占用10M+的内存,系统进程之间共享这些内存。共享库:Zygote进程预加载的共享库。
启动过程:Zygote是由init进程通过解析init.rc脚本启动的。现代设备分为32位和64位,因此Zygote的启动需要区分处理。根据系统属性ro.zygote的值,加载不同的rc脚本,例如init.zygote32.rc、init.zygote32_64.rc、init.zygote64.rc、init.zygote64_32.rc。这些脚本定义了Zygote的启动参数和行为。
以init.zygote64.rc为例,相关脚本如下:
service zygote /system/bin/app_process64 -Xzygote /system/bin --zygote --start-system-server class main priority -20 user root group root readproc socket zygote stream 660 root system onrestart write /sys/android_power/request_state wake onrestart write /sys/power/state on onrestart restart audioserver onrestart restart cameraserver onrestart restart media onrestart restart netd onrestart restart wificond writepid /dev/cpuset/foreground/tasks
Zygote的启动过程可以分为两个主要部分:
Native世界:Zygote通过app_process启动,其入口是app_main.cpp中的main函数。主要步骤包括启动Android虚拟机、注册Android的JNI函数,并通过参数--zygote和--start-system-server来指示app_process启动ZygoteInit。Java世界:Zygote进入Java世界后,执行ZygoteInit的main函数。主要步骤包括注册一个用于进程间通信的socket、预加载资源、启动System Server,并进入一个循环等待新的进程请求。
其他问题点:
为何使用socket而不是binder:Zygote通过fork创建新进程,而binder是多线程的,使用binder可能会导致死锁。因为fork只复制当前线程到子进程,其他线程在子进程中会消失,如果父进程在fork前获取了锁,子进程在尝试获取同一个锁时会导致死锁。为何通过Zygote孵化程序:使用Zygote孵化程序有两个主要好处:一是缩短应用启动时间,因为Zygote预加载了各种资源和虚拟机,新进程可以直接继承这些资源;二是优化共享内存,因为所有从Zygote fork出来的进程可以共享预加载的资源,如主题图片。Zygote设计的缺点:所有应用进程都是从同一个进程fork出来的,这会破坏地址空间布局随机化(ASLR),这是一种对抗代码注入攻击的重要安全手段。

以上就是Android框架简介–启动过程–Zygote的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/11199.html
微信扫一扫
支付宝扫一扫