[Android]Android系统启动流程源码分析

简介:


以下内容为原创,欢迎转载,转载请注明
来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5013863.html

Android系统启动流程源码分析

首先我们知道,Android是基于Linux的,当Linux内核加载完成时就会自动启动一个init的进程。
又因为我们每当我们启动一个App时,就会生成一个新的dalvik实例,并处于一个新的进程(当然一个App也可能是多进程的)。
当我们打开第一个App的时候,就会通过init进程fork出一个zygote进程。之后打开新的App的时候都会fork之前的zygote进程。

fork一个zygote进程时,会进入com.android.internal.os.ZygoteInitmain方法进行初始化操作:

  • 预加载资源

    // ...
    preloadClasses();
    preloadResources();
    preloadOpenGL();
    preloadSharedLibraries();
    preloadTextResources();
    // Ask the WebViewFactory to do any initialization that must run in the zygote process,
    // for memory sharing purposes.
    WebViewFactory.prepareWebViewInZygote();
    // ...
  • 从第一个zygote进程forkSystemServer进程,这个进程提供各种ManagerService

startSystemServer(abiList, socketName);

private static boolean startSystemServer(String abiList, String socketName)
            throws MethodAndArgsCaller, RuntimeException {
    int pid;
    // ...
    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",
            "--capabilities=" + capabilities + "," + capabilities,
            "--nice-name=system_server",
            "--runtime-args",
            "com.android.server.SystemServer",
        };
    /* Request to fork the system server process */
    pid = Zygote.forkSystemServer(
            parsedArgs.uid, parsedArgs.gid,
            parsedArgs.gids,
            parsedArgs.debugFlags,
            null,
            parsedArgs.permittedCapabilities,
            parsedArgs.effectiveCapabilities);
        // ...
}
  • Fork完SystemServer进程之后,继续接下来在handleSystemServerProcess方法中传入参数到SystemServer
  • RuntimeInit.zygoteInit(parsedArgs.targetSdkVersion, parsedArgs.remainingArgs, cl);
    注意,这里传入的参数是forkSystemServer进程后剩下的参数(parsedArgs.remainingArgs),其实只剩下了com.android.server.SystemServer这个参数了。

接下来继续调用applicationInit ,传入参数:

private static void applicationInit(int targetSdkVersion, String[] argv, ClassLoader classLoader)
            throws ZygoteInit.MethodAndArgsCaller {
    final Arguments args;
    // ...
    args = new Arguments(argv);
    // ...
}

解析成Arguments后,得到了一个startClass对象,这个startClass其实就是刚刚的那个com.android.server.SystemServer

接下来,继续调用 invokeStaticMain

private static void invokeStaticMain(String className, String[] argv, ClassLoader classLoader) throws ZygoteInit.MethodAndArgsCaller {
    Class<?> cl;
    // ...
    cl = Class.forName(className, true, classLoader);
    // ...
    m = cl.getMethod("main", new Class[] { String[].class });
    // ...
    throw new ZygoteInit.MethodAndArgsCaller(m, argv);
}

就是调用通过反射得到com.android.server.SystemServer(也就是上面的startClass)的main(argv[])方法,然后手动抛一个携带了这个main(argv[])方法的MethodAndArgsCaller异常,但是这个异常是在ZygoteInit.main()方法中被catch,然后去调用它的run()方法,当然这个run()方法中会再去通过反射调用携带的main()方法(这个绕法真是有点坑爹--。):

public static class MethodAndArgsCaller extends Exception implements Runnable {
    // ...
    public void run() {
        // ...
        mMethod.invoke(null, new Object[] { mArgs });
        // ...
    }
    // ...
}

绕了这么一大圈,终于通过MethodAndArgsCaller调用SystemServermain()方法了,代码很简单,直接new了之后run

new SystemServer().run();

接着,我们看SystemServerrun方法:

// ... (省略初始化当前的language、locale、country、指纹、用户等信息的初始化准备工作)
// 设置当前进程设置优先级为THREAD_PRIORITY_FOREGROUND(-2)
android.os.Process.setThreadPriority(
    android.os.Process.THREAD_PRIORITY_FOREGROUND);
android.os.Process.setCanSelfBackground(false);
// 初始化主线程Looper
Looper.prepareMainLooper();
// ...
// 启动消息循环
Looper.loop()

然后调用createSystemContext()方法创建初始化system context,这个待会再展开。

创建SystemServiceManager

mSystemServiceManager = new SystemServiceManager(mSystemContext);
LocalServices.addService(SystemServiceManager.class, mSystemServiceManager);

使用SystemServiceManager去通过以下方法创建启动各个Service

  1. startBootstrapServices():
  • com.android.server.pm.Installer:提供安装、卸载App等服务
  • com.android.server.am.ActivityServiceManager:提供Activity等组件的管理的服务,这个比较复杂暂且再挖个坑。
  • com.android.server.power.PowerManagerService:电源管理的服务。
  • com.android.server.lights.LightsService:LED管理和背光显示的服务。
  • com.android.server.display.DisplayManagerService:提供显示的生命周期管理,根据物理显示设备当前的情况决定显示配置,在状态改变时发送通知给系统和应用等服务。
  • com.android.server.pm.PackageManagerService:管理所有的.apk
  • com.android.server.pm.UserManagerService:提供用户相关服务。
  • 通过startSensorService()本地方法启动Sensor服务。
  1. startCoreServices();
  • com.android.server.BatteryService:电量服务,需要LightService
  • com.android.server.usage.UsageStatsService:提供收集统计应用程序数据使用状态的服务。
  • com.android.server.webkit.WebViewUpdateService:私有的服务(@hide),用于WebView的更新。
  1. startOtherServices();
  • com.android.server.accounts.AccountManagerService:提供所有账号、密码、认证管理等等的服务。
  • com.android.server.content.ContentService:用户数据同步的服务。
  • com.android.server.VibratorService:震动服务。
  • IAlarmManager:提醒服务。
  • android.os.storage.IMountService:存储管理服务。
  • com.android.server.NetworkManagementService:系统网络连接管理服务。
  • com.android.server.net.NetworkStatsService:收集统计详细的网络数据服务。
  • com.android.server.net.NetworkPolicyManagerService:提供低网络策略规则管理服务。
  • com.android.server.ConnectivityService:提供数据连接服务。
  • com.android.server.NetworkScoreServiceandroid.net.NetworkScoreManager的备份服务。
  • com.android.server.NsdService:网络发现服务(Network Service Discovery Service)。
  • com.android.server.wm.WindowManagerService:窗口管理服务。
  • com.android.server.usb.UsbService:USB服务。
  • com.android.server.SerialService:串口服务。
  • com.android.server.NetworkTimeUpdateService:网络时间同步服务。
  • com.android.server.CommonTimeManagementService:管理本地常见的时间配置的服务,当网络配置变化时会重新配置本地服务。
  • com.android.server.input.InputManagerService:事件传递分发服务。
  • com.android.server.TelephonyRegistry:提供电话注册管理的服务。
  • com.android.server.ConsumerIrService:远程控制服务。
  • com.android.server.audio.AudioService:音量、铃声、声道等管理服务。
  • com.android.server.MmsServiceBrokerMmsService的代理,因为MmsService运行在电话进程中,可能随时crash,它会通过一个connectionMmsService建立一个桥梁,MmsService实现了公开的SMS/MMS的API。
  • TelecomLoaderService
  • CameraService
  • AlarmManagerService
  • BluetoothService
  • 还有其它很多很多Service,这方法竟然有近1000行……

startOtherServices()方法的最后:

mActivityManagerService.systemReady(new Runnable() {
    @Override
    public void run() {
        // 下面仍然是各种Service的启动...
    }
}

调用这个方法用来告诉ActivityManagerService,此时可以运行第三方的代码了(注意:这里的Home界面、Launcher等内置的App也算是第三方的App)。

public void systemReady(final Runnable goingCallback) {
    // ...
    if (mSystemReady) {
        // 回调到SystemServer,继续启动各种Service
        if (goingCallback != null) {
            goingCallback.run();
        }
        return;
    }
    // ...

    ResolveInfo ri = mContext.getPackageManager().resolveActivity(new Intent(Intent.ACTION_FACTORY_TEST), STOCK_PM_FLAGS);
    // ...
    ActivityInfo ai = ri.activityInfo;
    ApplicationInfo app = ai.applicationInfo;
    // ...从PackageManager中获取要打开的HomeActivity
    mTopComponent = new ComponentName(app.packageName, ai.name);
    // ...
    // 启动第一个Home界面
    startHomeActivityLocked(mCurrentUserId, "systemReady");

    // ...
    // 广播通知启动完成
    broadcastIntentLocked(/*...*/, mCurrentUserId);
    broadcastIntentLocked(/*...*/, UserHandle.USER_ALL);
    // ...
}

启动Home界面的startHomeActivityLocked方法,调用mStackSupervisor启动HomeActivity

boolean startHomeActivityLocked(int userId, String reason) {
    // ...
    Intent intent = getHomeIntent();
    // ...
    intent.setFlags(intent.getFlags() | Intent.FLAG_ACTIVITY_NEW_TASK);
    mStackSupervisor.startHomeActivity(intent, aInfo, reason);
    // ...
}

Intent getHomeIntent() {
    Intent intent = new Intent(mTopAction, mTopData != null ? Uri.parse(mTopData) : null);
    // 设置前面获取到的mTopComponent
    intent.setComponent(mTopComponent);
    // ...
    intent.addCategory(Intent.CATEGORY_HOME);
    // ...
}

到此为止,SystemServer start完毕,并且启动了Home界面。



然后我们再回过头去看看在我们前面创建系统级的ContextcreateSystemContext)的时候做了什么:

ActivityThread activityThread = ActivityThread.systemMain();
mSystemContext = activityThread.getSystemContext();
mSystemContext.setTheme(android.R.style.Theme_DeviceDefault_Light_DarkActionBar);

首先调用了ActivityThread的静态方法systemMain()

public static ActivityThread systemMain() {
    // ...
    ActivityThread thread = new ActivityThread();
    thread.attach(true);
    return thread;
}

创建一个ActivityThread,然后调用它的attach()方法:

thread.attach(true);

private void attach(boolean system) {
    if (!system) {
        // ...
    }else{
        // ...
        mInstrumentation = new Instrumentation();
        ContextImpl context = ContextImpl.createAppContext(this, getSystemContext().mPackageInfo);
        mInitialApplication = context.mPackageInfo.makeApplication(true, null);
        mInitialApplication.onCreate();
        // ...
    }
}

参数system表示,是否是系统级的线程,现在我们是启动整个Android系统,显然当前传入的参数为true。所以进入else,首先,创建一个InstrumentationInstrumentation是什么?暂时先挖个坑。接着通过System Context创建一个ContextImpl,然后使用它的LoadedApk::makeApplication方法来创建整个应用的Application对象,然后调用ApplicationonCreate方法。

然后看下LoadedApk::makeApplication方法的实现:

public Application makeApplication(boolean forceDefaultAppClass,
            Instrumentation instrumentation) {
    // 只有第一次调用makeApplication才会往下执行
    if (mApplication != null) {
        return mApplication;
    }
    // 初始化系统的Application,所以appClass是"android.app.Application"
    String appClass = mApplicationInfo.className;
    if (forceDefaultAppClass || (appClass == null)) {
        appClass = "android.app.Application";
    }
    // ...
    ContextImpl appContext = ContextImpl.createAppContext(mActivityThread, this);
    app = mActivityThread.mInstrumentation.newApplication(
            cl, appClass, appContext);
    appContext.setOuterContext(app);
    // ...  
}

创建appContext,然后通过Instrumentation生成Application对象,并给appContext设置外部引用。

本文转自天天_byconan博客园博客,原文链接:http://www.cnblogs.com/tiantianbyconan/p/5013863.html ,如需转载请自行联系原作者
相关文章
|
2月前
|
人工智能 搜索推荐 物联网
Android系统版本演进与未来展望####
本文深入探讨了Android操作系统从诞生至今的发展历程,详细阐述了其关键版本迭代带来的创新特性、用户体验提升及对全球移动生态系统的影响。通过对Android历史版本的回顾与分析,本文旨在揭示其成功背后的驱动力,并展望未来Android可能的发展趋势与面临的挑战,为读者呈现一个既全面又具深度的技术视角。 ####
|
2月前
|
IDE Java 开发工具
移动应用与系统:探索Android开发之旅
在这篇文章中,我们将深入探讨Android开发的各个方面,从基础知识到高级技术。我们将通过代码示例和案例分析,帮助读者更好地理解和掌握Android开发。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和技巧。让我们一起开启Android开发的旅程吧!
|
28天前
|
监控 Java Android开发
深入探索Android系统的内存管理机制
本文旨在全面解析Android系统的内存管理机制,包括其工作原理、常见问题及其解决方案。通过对Android内存模型的深入分析,本文将帮助开发者更好地理解内存分配、回收以及优化策略,从而提高应用性能和用户体验。
|
29天前
|
存储 安全 Android开发
探索Android系统的最新安全特性
在数字时代,智能手机已成为我们生活中不可或缺的一部分。随着技术的不断进步,手机操作系统的安全性也越来越受到重视。本文将深入探讨Android系统最新的安全特性,包括其设计理念、实施方式以及对用户的影响。通过分析这些安全措施如何保护用户免受恶意软件和网络攻击的威胁,我们希望为读者提供对Android安全性的全面了解。
|
2月前
|
监控 Java Android开发
深入探讨Android系统的内存管理机制
本文将深入分析Android系统的内存管理机制,包括其内存分配、回收策略以及常见的内存泄漏问题。通过对这些方面的详细讨论,读者可以更好地理解Android系统如何高效地管理内存资源,从而提高应用程序的性能和稳定性。
82 16
|
2月前
|
安全 Android开发 iOS开发
深入探讨Android与iOS系统的差异及未来发展趋势
本文旨在深入分析Android和iOS两大移动操作系统的核心技术差异、用户体验以及各自的市场表现,进一步探讨它们在未来技术革新中可能的发展方向。通过对比两者的开放性、安全性、生态系统等方面,本文揭示了两大系统在移动设备市场中的竞争态势和潜在变革。
|
2月前
|
算法 JavaScript Android开发
|
2月前
|
安全 搜索推荐 Android开发
揭秘安卓与iOS系统的差异:技术深度对比
【10月更文挑战第27天】 本文深入探讨了安卓(Android)与iOS两大移动操作系统的技术特点和用户体验差异。通过对比两者的系统架构、应用生态、用户界面、安全性等方面,揭示了为何这两种系统能够在市场中各占一席之地,并为用户提供不同的选择。文章旨在为读者提供一个全面的视角,理解两种系统的优势与局限,从而更好地根据自己的需求做出选择。
117 2
|
2月前
|
安全 搜索推荐 程序员
深入探索Android系统的碎片化问题及其解决方案
在移动操作系统的世界中,Android以其开放性和灵活性赢得了广泛的市场份额。然而,这种开放性也带来了一个众所周知的问题——系统碎片化。本文旨在探讨Android系统碎片化的现状、成因以及可能的解决方案,为开发者和用户提供一种全新的视角来理解这一现象。通过分析不同版本的Android系统分布、硬件多样性以及更新机制的影响,我们提出了一系列针对性的策略,旨在减少碎片化带来的影响,提升用户体验。
|
2月前
|
安全 Android开发 iOS开发
深入探索iOS与Android系统的差异性及优化策略
在当今数字化时代,移动操作系统的竞争尤为激烈,其中iOS和Android作为市场上的两大巨头,各自拥有庞大的用户基础和独特的技术特点。本文旨在通过对比分析iOS与Android的核心差异,探讨各自的优势与局限,并提出针对性的优化策略,以期为用户提供更优质的使用体验和为开发者提供有价值的参考。