安卓系统的启动流程(源码分析)
来源:互联网 发布:天津seo网络推广 编辑:程序博客网 时间:2024/05/20 22:37
第一步:
Android 的执行流程,首先系统会启动Linux内核,然后内核会加载各种数据结构跟驱动程序,当驱动启动完毕之后,就会开启Android系统并加载系统第一个用户级别程序init,然后在init的main方法中去创建各种文件夹mkdir()及挂载设备目录mount(),初始化log日志,跟解析init.rc配置文件。
int main(int argc, char **argv){
...
// 创建各种文件夹和挂载目录.
mkdir("/dev", 0755);
...
// 初始化日志.
log_init();
// 解析配置文件.
init_parse_config_file("/init.rc")
...
return 0;
}
第二步:加载Init.rc文件. 主要启动了一个Zygote(孵化器)进程, 此进程是Android系统启动关键服务的一个母进程.
socket zygote stream 666
onrestart write /sys/android_power/request_state wake
onrestart write /sys/power/state on
onrestart restart media
第三步:
在解析配置文件时会通过镜像app_process去调用app_main中的main方法,然后在他的main方法里去调用appRuntime.start()方法,然而AppRuntime中是没有start方法,所以他调用的是他父类AndroidRuntime里的start方法,然后在他的run方法中去启动了虚拟机startVm()。
int main(int argc, const char* const argv[])
{
// 定义Android运行时环境.
AppRuntime runtime;
int i = runtime.addVmArguments(argc, argv);
...
bool startSystemServer = (i < argc) ?
strcmp(argv[i], "--start-system-server") == 0 : false;
setArgv0(argv0, "zygote");
set_process_name("zygote");
// 使用运行时环境启动Zygote的初始化类.
runtime.start("com.android.internal.os.ZygoteInit",
startSystemServer);
...
}
{
// 定义Android运行时环境.
AppRuntime runtime;
int i = runtime.addVmArguments(argc, argv);
...
bool startSystemServer = (i < argc) ?
strcmp(argv[i], "--start-system-server") == 0 : false;
setArgv0(argv0, "zygote");
set_process_name("zygote");
// 使用运行时环境启动Zygote的初始化类.
runtime.start("com.android.internal.os.ZygoteInit",
startSystemServer);
...
}
第四步:跟注册JNI startReg以及加载ZygoteInit并执行它的main方法,在他的main方法中通过preloadClass()反射预加载系统运行时所依赖的核心类跟资源文件,该操作是一个非常耗时的操作,然后去调用它本身的startSystemServer()方法,在该方法中创建了一个String[]型的数据,然后再通过forkSystemServer()并将数组中的数据传递给了SystemServer类。
public static void main(String argv[]) {
// 加载系统运行依赖的class类.
...
if (argv[1].equals("true")) {
// Zygote孵化器进程开始孵化系统核心服务.
startSystemServer();
} else if (!argv[1].equals("false")) {
throw new RuntimeException(argv[0] + USAGE_STRING);
}
...
}
private static boolean startSystemServer()
throws MethodAndArgsCaller, RuntimeException {
String args[] = {
"--setuid=1000",
"--setgid=1000",
"--setgroups=1001,1002,1003,1004,1005,1006,1007,1008,1009,1010,3001,3002,3003",
"--capabilities=130104352,130104352",
"--runtime-init",
"--nice-name=system_server",
"com.android.server.SystemServer",
};
...
// 孵化器分叉开启SystemServer类, 并且把上面定义的参数.
// 传递给此类. 用于启动系统关键服务.
pid = Zygote.forkSystemServer(
parsedArgs.uid, parsedArgs.gid,
parsedArgs.gids, debugFlags, null,
parsedArgs.permittedCapabilities,
parsedArgs.effectiveCapabilities);
...
}
> #### Zygote进程分叉出SystemServer类, main函数如下:
public static void main(String[] args) {
...
// 加载本地的动态链接库.
System.loadLibrary("android_servers");
// 调用动态链接库中的c函数.
init1(args);
}
// 这里init1的函数定义在frameworks\base\services\jni\com_android_server_SystemServer.cpp下的方法.
native public static void init1(String[] args);
第五步:
紧接着在SystemServer的main方法里,调用init1();但是他是一个没有方法体的方法,它的方法体在SystemServer.cpp下,在该方法体中通过JNI调用System_init();
static JNINativeMethod gMethods[] = {
/* name, signature, funcPtr */
// 把native方法init1, 映射到android_server_SystemServer_init1. (这里是定义的函数指针)
{ "init1", "([Ljava/lang/String;)V", (void*) android_server_SystemServer_init1 },
};
static void android_server_SystemServer_init1(JNIEnv* env, jobject clazz)
{
// 转调
system_init();
}
// 此方法没有方法体.
extern "C" int system_init();
/* name, signature, funcPtr */
// 把native方法init1, 映射到android_server_SystemServer_init1. (这里是定义的函数指针)
{ "init1", "([Ljava/lang/String;)V", (void*) android_server_SystemServer_init1 },
};
static void android_server_SystemServer_init1(JNIEnv* env, jobject clazz)
{
// 转调
system_init();
}
// 此方法没有方法体.
extern "C" int system_init();
第六步:
进入到System_Init类中的main方法类,然后完成Native层的开启,然后在System_Init中调用init2()方法,该方法也是一个没有方法体的,他的方法体在SystemServer中init2()方法,从而回到SystemServer中执行init2()方法
extern "C" status_t system_init()
{
...
// 开启一些硬件相关的服务.
SensorService::instantiate();
...
// 获取Android运行时环境
AndroidRuntime* runtime = AndroidRuntime::getRuntime();
LOGI("System server: starting Android services.\n");
// 调用SystemServer类中静态方法init2. 从native层转到java层.
runtime->callStatic("com/android/server/SystemServer", "init2");
...
}
{
...
// 开启一些硬件相关的服务.
SensorService::instantiate();
...
// 获取Android运行时环境
AndroidRuntime* runtime = AndroidRuntime::getRuntime();
LOGI("System server: starting Android services.\n");
// 调用SystemServer类中静态方法init2. 从native层转到java层.
runtime->callStatic("com/android/server/SystemServer", "init2");
...
}
SystemServer下init2方法如下:
public static final void init2() {
Slog.i(TAG, "Entered the Android system server!");
// 进入Android系统服务的初始化.
Thread thr = new ServerThread();
thr.setName("android.server.ServerThread");
thr.start();
}
public static final void init2() {
Slog.i(TAG, "Entered the Android system server!");
// 进入Android系统服务的初始化.
Thread thr = new ServerThread();
thr.setName("android.server.ServerThread");
thr.start();
}
第七步:
在init2()方法中启动内部的serverThread类,在他的run方法中启动了framework的系统服务,如PackgeManagerService跟ActivityManagerService,当所有的服务被启动完成之后,framework也就相应的开启完成,然后就是加载launcher应用及所有安装的apk,完成整个安卓系统的启动,
@Override
public void run() {
...
// 初始化系统的服务, 并且把服务添加ServiceManager中, 便于以后系统进行统一管理.
ServiceManager.addService("entropy", new EntropyService());
...
// 调用了ActivityManagerService的systemReady的方法.
((ActivityManagerService)ActivityManagerNative.getDefault())
.systemReady(new Runnable() {
public void run() {
...
}
});
...
}
public void run() {
...
// 初始化系统的服务, 并且把服务添加ServiceManager中, 便于以后系统进行统一管理.
ServiceManager.addService("entropy", new EntropyService());
...
// 调用了ActivityManagerService的systemReady的方法.
((ActivityManagerService)ActivityManagerNative.getDefault())
.systemReady(new Runnable() {
public void run() {
...
}
});
...
}
ActivityManagerService下的systemReady方法如下:
public void systemReady(final Runnable goingCallback) {
...
// 调用了ActivityStack中的resumeTopActivityLocked去启动Activity
mMainStack.resumeTopActivityLocked(null);
}
> #### ActivityStack中的resumeTopActivityLocked方法如下:
final boolean resumeTopActivityLocked(ActivityRecord prev) {
// 找到第一个当前没有关闭的Activity, 系统刚刚系统没有任何Activity执行, 所以next为null
ActivityRecord next = topRunningActivityLocked(null);
// Remember how we'll process this pause/resume situation, and ensure
// that the state is reset however we wind up proceeding.
final boolean userLeaving = mUserLeaving;
mUserLeaving = false;
if (next == null) {
// There are no more activities! Let's just start up the
// Launcher...
if (mMainStack) {
// 开启Launcher应用的第一个Activity界面.
return mService.startHomeActivityLocked();
}
}
}
public void systemReady(final Runnable goingCallback) {
...
// 调用了ActivityStack中的resumeTopActivityLocked去启动Activity
mMainStack.resumeTopActivityLocked(null);
}
> #### ActivityStack中的resumeTopActivityLocked方法如下:
final boolean resumeTopActivityLocked(ActivityRecord prev) {
// 找到第一个当前没有关闭的Activity, 系统刚刚系统没有任何Activity执行, 所以next为null
ActivityRecord next = topRunningActivityLocked(null);
// Remember how we'll process this pause/resume situation, and ensure
// that the state is reset however we wind up proceeding.
final boolean userLeaving = mUserLeaving;
mUserLeaving = false;
if (next == null) {
// There are no more activities! Let's just start up the
// Launcher...
if (mMainStack) {
// 开启Launcher应用的第一个Activity界面.
return mService.startHomeActivityLocked();
}
}
}
home界面显示, 这时Android系统启动完毕. 进入到待机画面.
1 0
- 安卓系统的启动流程(源码分析)
- 安卓应用程序的启动流程(源码分析)
- Android系统的启动流程分析及如何看源码
- 安卓7.0 系统服务启动流程
- Zookeeper源码分析(1)- Zookeeper的启动流程
- (二)源码分析之一:mysqld的启动流程
- 源码分析Activity启动的流程
- Activity的启动流程源码分析
- Android 5.0 Camera系统源码分析(1):CameraService启动流程
- Android 5.0 Camera系统源码分析(1):CameraService启动流程
- Android 5.0 Camera系统源码分析(1):CameraService启动流程
- Android系统的启动流程简要分析
- Android系统的启动流程简要分析
- 安卓启动流程
- 安卓启动流程
- 安卓启动流程
- 安卓启动流程
- 源码篇——安卓启动流程
- anagrams(medium)
- XMG CALayer隐式动画
- java实例化对象
- 卡特兰数
- PHP 基础教程2
- 安卓系统的启动流程(源码分析)
- 二分查找
- 【iOS】配置和使用静态库
- UI设计——磨皮
- 一起talk C栗子吧( 第一百五十回:C语言实例--socket通信接口二)
- Leetcode 76. Minimum Window Substring
- LINUX SHELL控制结构
- 设计师和程序员-拓展知识关系网
- java读写文件,读超大文件