Android世界第一个activity启动过程

Android世界第一个activity启动过程

第一次使用Markdown,感觉不错。

Android系统从按下开机键一直到launcher的出现,是一个怎样的过程,中间都做出了什么操作呢,带着这些疑问开始源码之旅。

像windows操作系统一样,每个系统的启动都会有一个引导程序,在linux中,当引导程序启动linux内核后,会加载各种驱动和数据结构,当有了驱动之后,开始加载Android系统,开始进入linux世界的第一个进程:init进程。

在init.c的main中:

    int main(int argc, char **argv){
            umask(0);// 清除文件的默认属性
            mkdir("/dev", 0755); // 创建文件、挂载文件等操作
            ........
            init_parse_config_file("/init.rc");  // 解析文件
            .........
    }

在init.rc文件中:(该文件在system/core/rootdir目录下)

    // 设置一些全局环境变量
    export PATH /sbin:/vendor/bin:/system/sbin:/system/bin:/system/xbin
    export LD_LIBRARY_PATH /vendor/lib:/system/lib
    ..............
    // 创建基本的文件系统结构
    mkdir /data/misc 01771 system misc
    ..............
    // 启动一些服务
    service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server
    socket zygote stream 666
    onrestart write /sys/android_power/request_state wake
    onrestart write /sys/power/state on
    onrestart restart media
    onrestart restart netd
    .............

最重要的是这个zygote进程,zygote就是一个孵化器,类似于母进程一样,可以fork出很多的子进程,是Android的一个母进程,用来启动Android的其他服务进程。当media、netd等服务进程销毁后,zygote进程会自动重启这些服务进程

在App_Main.cpp文件中:

    int main(int argc, const char* const argv[]){
            ............................
             bool startSystemServer = (i < argc) ?
             strcmp(argv[i], "--start-system-server") == 0 : false;
             setArgv0(argv0, "zygote");
            set_process_name("zygote");
            runtime.start("com.android.internal.os.ZygoteInit",startSystemServer);
    }

在AndroidRuntime的start方法中

    void AndroidRuntime::start(const char* className, const bool startSystemServer){
            ....................
            //   开启java虚拟机,并加载好jni运行环境
            if (startVm(&mJavaVM, &env) != 0)
                goto bail;
            .............
            // 利用jni与java进行交互,加载ZygoteInit类
            startClass = env->FindClass(slashClassName);
            if (startClass == NULL) {
                LOGE("JavaVM unable to locate class ‘%s‘\n", slashClassName);
            } else {
                // 利用jni调用ZygoteInit类中的main方法
                startMeth = env->GetStaticMethodID(startClass, "main","([Ljava/lang/String;)V");
                if (startMeth == NULL) {
                    LOGE("JavaVM unable to find main() in ‘%s‘\n", className);
            } else {
                env->CallStaticVoidMethod(startClass, startMeth, strArray);
                if (env->ExceptionCheck())
                        threadExitUncaughtException(env);
            }
    }

在ZygoteInit.java中:

    public static void main(String argv[]) {
            // 设置Android运行时的最小堆大小5M
            VMRuntime.getRuntime().setMinimumHeapSize(5 * 1024 * 1024);
            ..............
            // 预加载一些常用的类,这些常用的类在2.3中有1800个左右,在4.2源码中大概有2400多个常用的
            // 像有些手机厂商手机的启动速度较快的,估计是对这里进行了优化
            preloadClasses();
            // 加载一些资源文件,array、drawable、color等xml文件
            preloadResources();
            ..............
             if (argv[1].equals("true")) {
                     //在SystemServer类中fork系统服务进程
                    startSystemServer();
             } else if (!argv[1].equals("false")) {
                    throw new RuntimeException(argv[0] + USAGE_STRING);
             }
    }
     private static boolean startSystemServer() throws MethodAndArgsCaller, RuntimeException {
             String args[];
            String ashmem_size = System.getProperty("gralloc.ashmem_size");
            if ((null != ashmem_size) && (0 != ashmem_size.length())) {
                args = new String[] {
                    "--setuid=1000",
                    "--setgid=1000",
                    "--setgroups=1001,1002,1003,1004,1005,1006,1007,1008,1009,1010,1018,3001,3002,3003,3006",
                    "--capabilities=130104352,130104352",
                    "--rlimit=8,",
                    "--runtime-init",
                    "--nice-name=system_server",
                    "com.android.server.SystemServer",
                };
                args[4] = args[4].concat(ashmem_size);
                args[4] = args[4].concat(",");
                args[4] = args[4].concat(ashmem_size);
            } else {
                args = new String[] {
                    "--setuid=1000",
                    "--setgid=1000",
                    "--setgroups=1001,1002,1003,1004,1005,1006,1007,1008,1009,1010,1018,3001,3002,3003,3006",
                    "--capabilities=130104352,130104352",
                    "--runtime-init",
                    "--nice-name=system_server",
                    "com.android.server.SystemServer",
                };
            }
            ..............................
            pid = Zygote.forkSystemServer(
                parsedArgs.uid, parsedArgs.gid,
                parsedArgs.gids, debugFlags, rlimits,
                parsedArgs.permittedCapabilities,
                parsedArgs.effectiveCapabilities);
    } catch (IllegalArgumentException ex) {
        throw new RuntimeException(ex);
    }

SystemServer类中:

     native public static void init1(String[] args);
             .........
             System.loadLibrary("android_servers");
             init1(args);
             .........
     }

首先加载android_servers这个so库,这个库在于systemServer父目录同级别下的jni目录中,对应的c文件是com_android_server_SystemServer.c。然后调用库中的init1方法,

     extern "C" int system_init();
    static void android_server_SystemServer_init1(JNIEnv* env, jobject clazz)
    {
        system_init();
    }
    static JNINativeMethod gMethods[] = {
        { "init1", "([Ljava/lang/String;)V", (void*) android_server_SystemServer_init1 },
    };
int register_android_server_SystemServer(JNIEnv* env)
{
return jniRegisterNativeMethods(env, "com/android/server/SystemServer",
        gMethods, NELEM(gMethods));
}

我们可以看到init1被注册到了android_server_SystemServer_init1 这个方法上了,在android_server_SystemServer_init1 方法中调用了system_init方法,这个方法出现在System_init.cpp中

extern "C" status_t system_init()
{
// 开启传感器服务
SensorService::instantiate();
if (!proc->supportsProcesses()) {
    AudioFlinger::instantiate();
    // 启动媒体播放服务
    MediaPlayerService::instantiate();
    CameraService::instantiate();
    AudioPolicyService::instantiate();
}
// 启动Android运行时
AndroidRuntime* runtime = AndroidRuntime::getRuntime();
.................
runtime->callStatic("com/android/server/SystemServer", "init2");
.................
return NO_ERROR;

在System_init.cpp类中的system_init()方法中:利用runtime 调用SystemServer的init2方法,init2方法描述如下:

public static final void init2() {
    // 开始进入Android系统服务
    Thread thr = new ServerThread();
    thr.setName("android.server.ServerThread");
    thr.start();
}

在run方法中:

...........
// 实例化各种系统服务
ContentService.main(context,factoryTest == SystemServer.FACTORY_TEST_LOW_LEVEL);
Slog.i(TAG, "System Content Providers");
ActivityManagerService.installSystemProviders();
Slog.i(TAG, "Battery Service");
battery = new BatteryService(context);
ServiceManager.addService("battery", battery);
Slog.i(TAG, "Lights Service");
lights = new LightsService(context);
............
ServiceManager.addService("vibrator", new VibratorService(context));
............
 ((ActivityManagerService)ActivityManagerNative.getDefault())
            .systemReady(new Runnable() {
        public void run() {
            ........
        });

ServerThread线程任务主要是new出系统的服务,然后添加到serviceManager统一管理,最后调用ActivityManagerService的systemReady方法中执行了mMainStack.resumeTopActivityLocked(null);也就是打开了第一个activity。

  final boolean resumeTopActivityLocked(ActivityRecord prev) {
    // 寻找没有被finish掉的第一个activity
    ActivityRecord next = topRunningActivityLocked(null);
    final boolean userLeaving = mUserLeaving;
    mUserLeaving = false;
    if (next == null) {
        if (mMainStack) {
            // 没有activity,启动launcher
            return mService.startHomeActivityLocked();
        }
    }
    .....................
  }

到此,Android世界的第一个activity已经成功启动,它就是Launcher中的主activity。

版权声明:本文为博主原创文章,未经博主允许不得转载(联系方式:QQ312037487 邮箱:[email protected])。

时间: 2024-11-05 19:17:54

Android世界第一个activity启动过程的相关文章

Android应用程序的Activity启动过程简要介绍和学习计划

文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6685853 在Android系统中,Activity和Service是应用程序的核心组件,它们以松藕合的方式组合在一起构成了一个完整的应用程序,这得益 于应用程序框架层提供了一套完整的机制来协助应用程序启动这些Activity和Service,以及提供Binder机制帮助它们相互间进行通信.在前 面的文章Android进程间通信(IPC)机制B

0-Android应用程序的Activity启动过程简要介绍和学习计划

源码分析 之 Activity启动过程简要介绍和学习计划 来源: http://blog.csdn.net/luoshengyang/article/details/6685853 声明: RTFSC(Read the fucking source code)是Linus的名言,也是学习IT技术一个重要手段.学习android最好手段就是对android进行系统分析,关于android系统的源码,CSDN的老罗分析分析是最系统一个.但是老罗的分析源码的blog,有几点不够好: 1.废话太多,可能

【Android】应用程序Activity启动过程分析

在Android系统中,有两种操作会引发Activity的启动,一种用户点击应用程序图标时,Launcher会为我们启动应用程序的主Activity:应用程序的默认Activity启动起来后,它又可以在内部通过调用startActvity接口启动新的Activity,依此类推,每一个Activity都可以在内部启动新的Activity.通过这种连锁反应,按需启动Activity,从而完成应用程序的功能. Activity的启动方式有两种,一种是显式的,一种是隐式的,隐式启动可以使得Activit

Android --- Zygote和System进程启动过程简要分析

Android --- Zygote和System进程启动过程简要分析 在看过<Android情景源代码>的Zygote启动章节后,作如下简要总结.Zygote进程在init进程启动过程中被以service服务的形式启动: service zygote /system/bin/app_process -Xzygote /system/bin --zygote --start-system-server class main socket zygote stream 660 root syste

Android组件体系之Activity启动模式解析

本文主要分析Activity的启动模式及使用场景. 一.Activity启动模式浅析 1.standard 标准模式,系统默认的启动模式.在启动Activity时,系统总是创建一个新的Activity实例.其缺点是:复用性差.占用内存,当Activity已经在栈顶时,还是会创建实例. 2.singleTop 这种模式可以实现栈顶复用的效果. 如果目标Activity已经存在于栈顶,则调用实例的 onNewIntent,否则创建一个新的实例,可以用于通知启动的内容显示,例如新闻客户端的内容页面.信

《深入透析Android》之 浅析Activity启动模式

前言: Activity的启动模式是一个既基础又容易忽视的问题,但是这个问题有个深刻的认识,对程序员写一个稳定高效的Android程序帮助很大,今天,在B哥引导下,我们对Activity启动模式.Intent Flags做了一番很好的探究. 探究历程: ①   什么是栈 ②   Activity栈 ③   Task ④  Activity启动模式 ⑤  Activity栈和Task联系 ⑥  Intent Flags  ⑦  Activity相关属性taskAffinity 1.    什么是栈

android获得上一个activity的返回值来设定当前按钮的可按性

每次想去转载别人的文章就不用自己写了,好想这样省事,但是路途就是那么的艰辛,每次看别人的博客然后自己做时会遇到各种各样的问题,人家的博客就那么几个步骤,然而我照着做时就会遇到奇葩问题,,哎,现在想起了曲婉婷的一首歌<没有什么不同>的歌词尽管痛的苦的没说的,但哪有一路走来都是顺风的,只要为了梦想不服输,再苦也不停止脚步.还是自己总结一下把!! 首先我为以前做都的项目的app新增加了个按钮,要求这个按钮在没获得上一个activity返回过来的值前不能按,这样我就找到了方法,就是使用startAct

【转载】【凯子哥带你学Framework】Activity启动过程全解析

It's right time to learn Android's Framework ! 前言 一个App是怎么启动起来的? App的程序入口到底是哪里? Launcher到底是什么神奇的东西? 听说还有个AMS的东西,它是做什么的? Binder是什么?他是如何进行IPC通信的? Activity生命周期到底是什么时候调用的?被谁调用的? 等等... 你是不是还有很多类似的疑问一直没有解决?没关系,这篇文章将结合源码以及大量的优秀文章,站在巨人的肩膀上,更加通俗的来试着解释一些问题.但是毕

【凯子哥带你学Framework】Activity启动过程全解析

It's right time to learn Android's Framework ! 前言 学习目标 写作方式 主要对象功能介绍 主要流程介绍 zygote是什么有什么作用 SystemServer是什么有什么作用它与zygote的关系是什么 ActivityManagerService是什么什么时候初始化的有什么作用 Launcher是什么什么时候启动的 Instrumentation是什么和ActivityThread是什么关系 如何理解AMS和ActivityThread之间的Bi