Dalvik VM进程系统浅析学习记录

本文详细解析了Android系统的启动流程,从Boot Loader到Linux Kernel,再到init进程和Zygote的启动。Zygote作为Android系统的孵化器,通过fork()创建SystemServer进程,避免了多线程fork可能导致的死锁问题。同时,Zygote预先加载资源,提高应用启动效率。此外,文章讨论了为何SystemServer不在init直接启动以及不采用Binder进行IPC的原因。

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

1.Android启动流程 

Boot Rom Boot loader  Kernel init  zygote Systemserver

Lancher

init main函数 

init.rc(Action  Command Service Options service解析流程)

 1)启动一系列守护进程

 2)zygote

      (fork zygote的进程)SystemServer 开启一系列的服务

          AMS WMS PKMS PMS 。。。80多个

      Lancher -> app -> fork从 zygote子进程出来 到app

   

 3)media service

总结init:1、创建和挂在启动所需要文件目录

                2、初始化和启动属性服务

                3、解析init.rc配置文件并“启动Zgyote进程”

 

2.分析Zygote的启动过程 

fork创建一个子进程(不干什么,指向fork拷贝的进程,干了什么,才会fork出自己的那个空间)

     返回值=0  在子进程中

    返回值>0  在父进程

    返回值<0  fork失败

 

3.启动SystemServer进程 (引导服务)AMS在这里启动的

 

1.你了解 Android 系统启动流程吗?

A:当按电源键触发开机,首先会从 ROM 中预定义的地方加载引导程序 BootLoader 到 RAM 中,并执行 BootLoader 程序启动 Linux Kernel, 然后启动用户级别的第一个进程: init 进程。init 进程会解析init.rc 脚本做一些初始化工作,包括挂载文件系统、创建工作目录以及启动系统服务进程等,其中系统服务进程包括 Zygote、service manager、media 等。在 Zygote 中会进一步去启动 system_server 进程,然后在 system_server 进程中会启动 AMS、WMS、PMS 等服务,等这些服务启动之后,AMS 中就会打开 Launcher 应用的 home Activity,最终就看到了手机的 "桌面"。

2.system_server 为什么要在 Zygote 中启动,而不是由 init 直接启动呢?

A:Zygote 作为一个孵化器,可以提前加载一些资源,这样 fork() 时基于 Copy-On-Write 机制创建的其他进程就能直接使用这些资源,而不用重新加载。比如 system_server 就可以直接使用 Zygote 中的 JNI函数、共享库、常用的类、以及主题资源。

3.为什么要专门使用 Zygote 进程去孵化应用进程,而不是让 system_server 去孵化呢?

A:首先 system_server 相比 Zygote 多运行了 AMS、WMS 等服务,这些对一个应用程序来说是不需要的。另外进程的 fork() 对多线程不友好,仅会将发起调用的线程拷贝到子进程,这可能会导致死锁,而system_server 中肯定是有很多线程的。

4.能说说具体是怎么导致死锁的吗?

在 POSIX 标准中,fork 的行为是这样的:复制整个用户空间的数据(通常使用 copy-on-write 的策略,所以可以实现的速度很快)以及所有系统对象,然后仅复制当前线程到子进程。这里:所有父进程中别的线程,到了子进程中都是突然蒸发掉的对于锁来说,从 OS 看,每个锁有一个所有者,即最后一次 lock 它的线程。假设这么一个环境,在 fork

之前,有一个子线程 lock 了某个锁,获得了对锁的所有权。fork 以后,在子进程中,所有的额外线程都人间蒸发了。而锁却被正常复制了,在子进程看来,这个锁没有主人,所以没有任何人可以对它解锁。当子进程想 lock 这个锁时,不再有任何手段可以解开了。程序发生死锁

5.Zygote 为什么不采用 Binder 机制进行 IPC 通信?

A:Binder 机制中存在 Binder 线程池,是多线程的,如果 Zygote 采用 Binder 的话就存在上面说的fork() 与 多线程的问题了。其实严格来说,Binder 机制不一定要多线程,所谓的 Binder 线程只不过是在循环读取 Binder 驱动的消息而已,只注册一个 Binder 线程也是可以工作的,比如 service manager就是这样的。实际上 Zygote 尽管没有采取 Binder 机制,它也不是单线程的,但它在 fork() 前主动停止了其他线程,fork() 后重新启动了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值