Android Framework学习笔记(二)Zygote进程启动过程,万字总结

本文详细分析了Android系统中的Zygote进程启动过程,包括由init进程启动Zygote,Zygote初始化DDMS,解析启动参数,注册Zygote Socket,预加载类和资源,以及启动SystemServer进程等关键步骤。此外,还探讨了预加载过程中的类、资源、OpenGL以及WebView的初始化。最后,文章提到了Zygote如何监听socket并准备创建新的应用进程。

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

linux的根进程,android系统是基于linux系统的,因此可以算作是整个android操作系统的第一个进程;

Zygote进程

android系统的根进程,可以作用Zygote进程fork出SystemServer进程和各种应用进程;

SystemService进程

主要是在这个进程中启动系统的各项服务,比如ActivityManagerService,PackageManagerService,WindowManagerService服务等;

各种应用进程

启动自己编写的客户端应用时,一般都是重新启动一个应用进程,有自己的虚拟机与运行环境;

Zygote进程的执行过程


其中Zygote进程由init进程启动,SystemServer进程和应用进程由Zygote进程启动。本文依据7.0源码,主要分析Zygote进程的启动流程。init进程在启动Zygote进程时会调用ZygoteInit#main()。

frameworks/base/core/java/com/android/internal/os/ZygoteInit.java

ZygoteInit#main()

public static void main(String argv[]) {

try {

//设置DDMS可用

RuntimeInit.enableDdms(); //1

//初始化启动参数

boolean startSystemServer = false;

String socketName = “zygote”;

String abiList = null;

//2

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

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

startSystemServer = true;

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

abiList = argv[i].substring(ABI_LIST_ARG.length());

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

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

} else {

throw new RuntimeException("Unknown command line argument: " + argv[i]);

}

}

if (abiList == null) {

throw new RuntimeException(“No ABI list supplied.”);

}

//注册Zygote用的Socket

registerZygoteSocket(socketName); //3

//预加载类和资源

preload(); //4

//启动SystemServer进程

if (startSystemServer) {

//startSystemServer(abiList, socketName); //5 old way

Runnable r = forkSystemServer(abiList, socketName, zygoteServer);

// child (system_server) process.

if (r != null) {

r.run();

return;

}

}

//监听socket,启动新的应用进程

runSelectLoop(abiList); //6

closeServerSocket();

} catch (MethodAndArgsCaller caller) {

//通过反射调用SystemServer#main()

caller.run();

} catch (RuntimeException ex) {

Log.e(TAG, “Zygote died with exception”, ex);

closeServerSocket();

throw ex;

}

}

注释1设置DDMS可用,可以发现DDMS启动的时机还是比较早的,在整个Zygote进程刚刚开始要启动的时候就设置可用了。

注释2的循环主要是解析main方法的参数获取是否需要启动SystemService进程,获取abi列表,获取scoket连接名称 。(这里需要注意的是:android系统中进程之间通讯的方式是Binder,但是有一个例外是SystemService进程与Zygote进程之间是通过Socket的方式进行通讯的)

注释3处通过registerZygoteSocket函数来创建一个Server端的Socket,这个name为”zygote”的Socket用来等待ActivityManagerService来请求Zygote来创建新的应用程序进程。

注释4处用来预加载类和资源。

注释5处用来启动SystemServer进程,这样系统的关键服务也会由SystemServer进程启动起来。

注释6处调用runSelectLoop函数监听socket来等待客户端请求。

由此可见,ZygoteInit的main函数主要做了4件事(注释3、4、5、6),接下来我们对主要的事件一一进行分析。

注册Server端的Socket


ZygoteInit#registerZygoteSocket()

private static void registerZygoteSocket(String socketName) {

if (sServerSocket == null) {

int fileDesc;

final String fullSocketName = ANDROID_SOCKET_PREFIX + socketName;

try {

String env = System.getenv(fullSocketName);

fileDesc = Integer.parseInt(env);

} catch (RuntimeException ex) {

throw new RuntimeException(fullSocketName + " unset or invalid", ex);

}

try {

FileDescriptor fd = new FileDescriptor();

fd.setInt$(fileDesc);

//不是使用IP和端口、而是使用fd创建socket

sServerSocket = new LocalServerSocket(fd); //1

} catch (IOException ex) {

throw new RuntimeException(

“Error binding to local socket '” + fileDesc + “’”, ex);

}

}

}

注释1处用来创建LocalServerSocket,也就是服务端的Socket。当Zygote进程将SystemServer进程启动后,就会在这个服务端的Socket上来等待ActivityManagerService请求Zygote进程来创建新的应用程序进程。

预加载类和资源


ZygoteInit#preload()

static void preload() {

beginIcuCachePinning();

preloadClasses(); //加载所需的各种class文件

preloadResources(); //加载资源文件

preloadOpenGL(); //初始化OpenGL

preloadSharedLibraries(); //加载系统Libraries

preloadTextResources(); //加载文字资源

// Ask the WebViewFactory to do any initialization that must run in the zygote process,

// for memory sharing purposes.

WebViewFactory.prepareWebViewInZygote(); //初始化WebView

endIcuCachePinning();

warmUpJcaProviders();

Log.d(TAG, “end preload”);

}

启动SystemServer进程


ZygoteInit#startSystemServer()

private static boolean startSystemServer(String abiList, String socketName)

throws MethodAndArgsCaller, RuntimeException {

long capabilities = posixCapabilitiesAsBits(

OsConstants.CAP_IPC_LOCK,

OsConstants.CAP_KILL,

OsConstants.CAP_NET_ADMIN,

OsConstants.CAP_NET_BIND_SERVICE,

OsConstants.CAP_NET_BROADCAST,

OsConstants.CAP_NET_RAW,

OsConstants.CAP_SYS_MODULE,

OsConstants.CAP_SYS_NICE,

OsConstants.CAP_SYS_RESOURCE,

OsConstants.CAP_SYS_TIME,

OsConstants.CAP_SYS_TTY_CONFIG

);

/* Containers run without this capability, so avoid setting it in that case */

if (!SystemProperties.getBoolean(PROPERTY_RUNNING_IN_CONTAINER, false)) {

capabilities |= posixCapabilitiesAsBits(OsConstants.CAP_BLOCK_SUSPEND);

}

/* Hardcoded command line to start the system server */

/* 1 */

String args[] = {

“–setuid=1000”,

“–setgid=1000”,

“–setgroups=1001,1002,1003,1004,1005,1006,1007,1008,1009,1010,1018,1021,1032,3001,3002,3003,3006,3007,3009,3010”,

“–capabilities=” + capabilities + “,” + capabilities,

“–nice-name=system_server”,

“–runtime-args”,

“com.android.server.SystemServer”,

};

ZygoteConnection.Arguments parsedArgs = null;

学习分享

在当下这个信息共享的时代,很多资源都可以在网络上找到,只取决于你愿不愿意找或是找的方法对不对了

很多朋友不是没有资料,大多都是有几十上百个G,但是杂乱无章,不知道怎么看从哪看起,甚至是看后就忘

如果大家觉得自己在网上找的资料非常杂乱、不成体系的话,我也分享一套给大家,比较系统,我平常自己也会经常研读。

2020最新上万页的大厂面试真题

七大模块学习资料:如NDK模块开发、Android框架体系架构…

只有系统,有方向的学习,才能在段时间内迅速提高自己的技术。

这份体系学习笔记,适应人群:
第一,学习知识比较碎片化,没有合理的学习路线与进阶方向。
第二,开发几年,不知道如何进阶更进一步,比较迷茫。
第三,到了合适的年纪,后续不知道该如何发展,转型管理,还是加强技术研究。如果你有需要,我这里恰好有为什么,不来领取!说不定能改变你现在的状态呢!
5%E9%9D%A2%E8%AF%95%E6%8B%BF%E9%AB%98%E8%96%AA%EF%BC%81.md)

[外链图片转存中…(img-ifqw6To3-1645160392398)]

七大模块学习资料:如NDK模块开发、Android框架体系架构…

[外链图片转存中…(img-xDDC27Mc-1645160392400)]

只有系统,有方向的学习,才能在段时间内迅速提高自己的技术。

这份体系学习笔记,适应人群:
第一,学习知识比较碎片化,没有合理的学习路线与进阶方向。
第二,开发几年,不知道如何进阶更进一步,比较迷茫。
第三,到了合适的年纪,后续不知道该如何发展,转型管理,还是加强技术研究。如果你有需要,我这里恰好有为什么,不来领取!说不定能改变你现在的状态呢!
由于文章内容比较多,篇幅不允许,部分未展示内容以截图方式展示 。如有需要获取完整的资料文档的朋友点击我的GitHub免费获取。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值