征服Android面试官路漫漫(四),再不了解你就out啦

//system/core/rootdir/init.rc

import /init.${ro.zygote}.rc

${ro.zygote}的取值有4种,在init.rc的同级目录/system/core/rootdir下,可以看到4个Zygote相关的配置文件,表示系统所支持程序的bit位数,

  1. init.zygote32.rc,Zygote进程的执行程序路径为/system/bin/app_process

  2. init.zygote64.rc,Zygote进程的执行程序路径为/system/bin/app_process64

  3. init.zygote32_64.rc,会启动两个Zygote进程,有两个执行程序,32为主模式

  4. init.zygote64_32.rc,会启动两个Zygote进程,有两个执行程序,64为主模式

我们看到init.zygote32.rc文件,

service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server

class main

priority -20

user root

group root readproc reserved_disk

socket zygote stream 660 root system

第一行中,service表示Zygote进程以服务的形式来启动,zygote则是进程的名字,/system/bin/app_process是执行程序的路径,后面几项则是传给执行程序的参数,其中--start-system-server表示在Zygote进程启动后需要启动SystemServer进程。

然后是最后一行,Zygote进程是使用socket来进行跨进程通信的,所以会创建一个名为zygote的socket,660表示访问权限rw-rw----,表示文件拥有者和同一群组用户具有读写权限。

init进程启动后,通过fork和execve来启动Zygote进程,

//system/core/init/service.cpp

bool Service::Start() {

//fork出子进程

pid = f
ork();

if (pid == 0) {//子进程会返回0,父进程会返回子进程的pid

//strs[0]是执行程序的路径,即execve会运行app_process

if (execve(strs[0], (char**) &strs[0], (char**) ENV) < 0) {

}

}

}

运行执行程序app_process的入口函数main,

//frameworks/base/cmds/app_process/app_main.cpp

int main(int argc, char* const argv[]){

if (zygote) {

//启动Zygote,进入ZygoteInit.main函数

runtime.start(“com.android.internal.os.ZygoteInit”, args, zygote);

}

}

至此Zygote就正式启动了。

综上,init进程读取配置文件init.rc后,fork出Zygote进程,通过execve函数执行Zygote的执行程序app_process,进入ZygoteInit类的main函数

下面详细分析app_main和ZygoteInit。

native层app_main

前边可知app_main.cpp的main函数会调用runtime.start(),

//frameworks/base/core/jni/AndroidRuntime.cpp

void AndroidRuntime::start(…){

//1. 启动java虚拟机

if (startVm(&mJavaVM, &env, zygote) != 0) {

return;

}

//2. 为java虚拟机注册JNI方法

if (startReg(env) < 0) {

return;

}

//根据传入的参数找到ZygoteInit类和他的main函数

//3. 通过JNI调用ZygoteInit的main函数

env->CallStaticVoidMethod(startClass, startMeth, strArray);

}

Java层ZygoteInit

来到ZygoteInit的main函数,

//ZygoteInit.java

public static void main(String argv[]) {

//是否要创建SystemServer

boolean startSystemServer = false;

//默认的socket名字

String socketName = “zygote”;

//是否要延迟资源的预加载

boolean enableLazyPreload = false;

for (int i = 1; i < argv.length; i++) {

if (“start-system-server”.equals(argv[i])) {

//在init.rc文件中,有–start-system-server参数,表示要创建SystemServer

startSystemServer = true;

} else if ("–enable-lazy-preload".equals(argv[i])) {

//init.rc没有这个参数,资源的预加载不会被延迟

enableLazyPreload = true;

} else if (argv[i].startsWith(SOCKET_NAME_ARG)) {

//init.rc可以通过–socket-name=指定socket名字来覆盖默认值

socketName = argv[i].substring(SOCKET_NAME_ARG.length());

}

}

//1. 创建服务端socket,名字为socketName即zygote

zygoteServer.registerServerSocket(socketName);

if (!enableLazyPreload) {

//2. 没有被延迟,就预加载资源

preload(bootTimingsTraceLog);

}

if (startSystemServer) {

//3. fork并启动SystemServer进程

startSystemServer(abiList, socketName, zygoteServer);

}

//4. 等待AMS请求(AMS会通过socket请求Zygote来创建应用程序进程)

zygoteServer.runSelectLoop(abiList);

}

总结一下native层的3个环节和Java层的4个环节:

SystemServer启动


SystemServer进程主要负责创建启动系统服务如AMS、WMS和PMS等

从前边可知SystemServer进程由Zygote进程fork出来并启动,在ZygoteInit类中,

//ZygoteInit.java

private static boolean startSystemServer(…){

String args[] = {

//…

//启动的类名:

“com.android.server.SystemServer”,

};

//fork进程,由native层实现

pid = Zygote.forkSystemServer();

//处理SystemServer进程

handleSystemServerProcess(parsedArgs);

}

private static void handleSystemServerProcess(…){

ZygoteInit.zygoteInit(…);

}

public static final void zygoteInit(…){

//启动binder线程池

ZygoteInit.nativeZygoteInit();

//内部经过层层调用,找到"com.android.server.SystemServer"类和他的main函数,然后执行

RuntimeInit.applicationInit(targetSdkVersion, argv, classLoader);

}

这里启动了binder线程池,SystemServer进程就可以用binder机制来跨进程通信了(Zygote进程是用socket来通信的),接着进入了SystemServer的main函数,

//SystemServer.java

public static void main(String[] args) {

new SystemServer().run();

}

private void run() {

//创建looper

Looper.prepareMainLooper();

//加载动态库libandroid_servers.so

System.loadLibrary(“android_servers”);

//创建系统上下文

createSystemContext();

//创建SSM,用于服务的创建、启动和生命周期管理

mSystemServiceManager = new SystemServiceManager(mSystemContext);

//服务根据优先级被分成3批来启动:

//启动引导服务,如AMS、PMS等

startBootstrapServices();

//启动核心服务

startCoreServices();

//启动其他服务

startOtherServices();

//开启looper循环

Looper.loop();

}

看下AMS的启动,

//SystemServer.java

private void startBootstrapServices() {

//由SSM创建启动

mActivityManagerService = mSystemServiceManager.startService(

ActivityManagerService.Lifecycle.class).getService();

mActivityManagerService.setSystemServiceManager(mSystemServiceManager);
动核心服务

startCoreServices();

//启动其他服务

startOtherServices();

//开启looper循环

Looper.loop();

}

看下AMS的启动,

//SystemServer.java

private void startBootstrapServices() {

//由SSM创建启动

mActivityManagerService = mSystemServiceManager.startService(

ActivityManagerService.Lifecycle.class).getService();

mActivityManagerService.setSystemServiceManager(mSystemServiceManager);

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值