android系统启动流程之SystemServer运行过程

news2024/11/19 5:35:38

SystemServer进程的启动流程:直接看代码:
SystemServer是Java中的一个进程,执行入口是SystemServer.java.main();

SystemServer.java.main();
  -->new SystemServer().run();
      -->createSystemContext();//创建系统上下文:虽然SystemServer没有界面,他也有这些操作
          -->ActivityThread acivityThread = ActivityThread.systemMain();
                -->ActivityThread thread = new ActivityThread();
                   thread.attach(true, 0);
                      -->mInstrumentation = new Instrumentation();
                         ContextImpl context = ContextImpl.createAppContext();
                         //makeApplication会加载各种资源:  apk(用assetManager加载Res,在下面这个地方做)
                         mInitialApplication = context.mPackageInfo.makeApplication(true, null);
                          -->context.setResources(packageInfo.getResources());
                         mInitialApplication.onCreate();
                   return thread;
             mSystemContext = activityThread.getSystemContext();
             mSystemContext.setTheme(DEFAULT_SYSTEM_THEME);
             //ui的系统上下文也创建 好了
             context  systemUiContext = activityThread.getSystemUiContext();
      //构建system manager service: 利用它去管理各种System Service, 后面才能去启动各种Services.
      -->mSystemServiceManager = new SystemServiceManager(mSystemContext);    
          
      -->run函数是重点,非常重要的点在于三个函数,以下三个函数的启动包含了90多个服务:
         startBootstrapServices(t);
         startCoreServices(t);
         startOtherServices(t);

         //死循环,有loop意味着它有handler
         Looper.loop();

上面代码注释中说道,SystemServiceManager这个对象是SystemServer进程中重要的数据结构,用于管理系统各种SystemService,
那么它具体是怎么做到的?在具体分析之前,先理清楚 以下几个概念:

  •  什么是SystemService:

系统各类服务需要封装的类,每一种系统服务都要直接或间接的继续这个SystemService类,成为一个SystemService的类对象,方便让SystemServiceManager统一管理。

  •  什么是SystemServiceManager:

是SystemServer中的一个非常重要的类,得力助手,SystemServer通过它管理各种Services,如AMS, WMS, PKMS等,并且这些服务必须封装成一个对象,这个类就是SystemService,也就是说SysermServiceManager管理的都是SystemService的类对象。这种模式有点类似Activity:通过FragmentManager去管理许多的Fragment类对象。

  •  什么是SystemServer:

它是进程,是系统服务端,管理 各种Services.

  •  什么是ServiceManager:

它也是一个进程,早上Zygote进程启动,它是由init进程通过解析init.rc后创建。

上面的这几个问题可以用下图来概括:

搞懂了以上的知识点之后,以ATMS为例分析,SystemSericeManager是如何管理这个ATMS的,ATMS是在以下接口中被启动的。

startBootstrapServices(t);
  //启动ATMS
  -->ActivityTaskManagerService atm = mSystemServiceManager.startService(ActivityTaskManagerService.LifeCycle.class).getService());
        -->ActivityTaskManagerService(Class<T> serviceClass): //拿到类可以通过类去反射,得到Methods.
              -->final T service;
                 service = construct.newIntance(mContext); //创建一个实例:即LifeCycle类的实例,在其构造函数中会实例化一个ATMS
                 startService(service); //启动服务
                    -->class<SystemService> serviceClass =  loadClassFromLoader(classname, this.getClass().getClassLoader());
                       return startService(serviceClass);
                          -->mServices.add(service); //mServices就是ArrayList<SystemService>数组,将ATMS这个SystemService对象添加到数组中。
                             service.onStart(); //本质就是调用了LifeCycle内部的ATMS服务实例的start()接口,下面有分析。

可以看看ActivityTaskManagerService它的父类是什么:
 class ActivityTaskManagerService extends IActivityTaskManager.Stub{}; 

疑问一,根据前面的分析,说系统各种服务都是继承SystemService类,为什以它这里不是继承至SystemService类呢?因为JAVA只能有一个父类,ATMS是一个服务,根据Binder的使用,各种ATMS需要继承一个Binder类(Stub类),但是为了让ATMS能满足上面的规则(需要继承至SystemService类),此时ActivityTaskManagerService内部定义了一个静态static的内部类LifeCycle,它继承至SystemService. 然后让ActivityTaskManagerService类对象成为LifeCycle的类成员, 这就解决是java语言中,如何让一个类可以继承两个父类的问题,后面对服务ATMS的操作转为LifeCycle中的操作。如下图代码所示:

    class ActivityTaskManagerService extends IActivityTaskManager.Stub{
        public static final class LifeCycle extends SystemService{
            private final ActivityTaskManagerService mService;
            public LifeCycle(){ //实 例化。
                mService = new ActivityTaskManagerService();
            }

            public void onStart(){ //对LifeCycle的所有操作都是对mService(即ATMS的操作)
               mService.start();
            }
        }
    }

以上是以ATMS为例进行分析说明,系统的90+种系统服务均是走类似的业务逻辑流程,可以按相同的方法进行分析,以下图这张图做最后一个总结。至此,安卓系统的整体分析流程结束。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/937036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unittest 笔记:unittest拓展生成HTM报告发送邮件

HTMLTestRunner 是一个unitest拓展可以生成HTML 报告 下载地址&#xff1a;GitHub: https://github.com/defnnig/HTMLTestRunner HTMLTestRunner是一个独立的py文件&#xff0c;可以放在Lib 作为第三方模块使用或者作为项目的一部分。 方式1&#xff1a; 验证是否安装成功&…

Flutter 状态管理引子

1、为了更好地了解状态管理&#xff0c;先看看什么是状态。 在类似Flutter这样的响应式编程框架中&#xff0c;我们可以认为U相关的开发就是对数据进行封装&#xff0c;将之转换为具体的U1布局或者组件。借用Flutter官网的一张图&#xff0c;可以把我们在第二部分做的所有开发…

AliOS-Things引入

目录 一、简介 1.1 硬件抽象层 1.2 AliOS-Things内核 rhino ​编辑 1.3 AliOS-Things组件 二、如何进行AliOS-Things开发 三、安装环境 安装python pip git 修改pip镜像源 安装aos-cube 一、简介 AliOS-Things是阿里巴巴公司推出的致力于搭建云端一体化LoT软件。AliOS-…

Linux操作系统--文件与目录结构

我们初步认识了Linux操作系统,下面我们进一步看看linux的文件与目录结构。 1.文件系统和挂载点 (1).当前的操作系统中查看文件系统 位置 > 计算机 这样你就可以看见当前操作系统中的所有目录和文件。如下所示: (2).挂载点 挂载点实际上就是linux中的磁盘文件系统的入口…

快速理解 X server, DISPLAY 与 X11 Forwarding

​ X server X server是X Window System &#xff08;简称X11或者X&#xff09;系统中的显示服务器&#xff08;display server&#xff09;&#xff0c;用于监听X client发送来的图形界面显示请求&#xff0c;并且将图形界面绘制并显示在屏幕&#xff08;screen&#xff09;…

粒子群算法的基本原理和Matlab实现

1.案例背景 1.1 PSO算法介绍 粒子群优化算法(Particle Swarm Optimization,PSO)是计算智能领域,除了蚁群算法,鱼群算法之外的一种群体智能的优化算法,该算法最早是由Kennedy和 Eberhart 在1995年提出的。PSO算法源于对鸟类捕食行为的研究,鸟类捕食时,每只鸟找到食物最简单有效…

webassembly003 ggml GGML Tensor Library part-3

关于pthread_create()和pthread_join() #include <stdio.h> #include <pthread.h>void *thread_func(void *arg) {int *num (int *)arg;printf("Hello from thread! arg%d\n", *num);pthread_exit(NULL); }int main() {pthread_t thread;int arg 10;i…

解锁开发中的创意:用户为中心的设计思维的力量

引言 设计思维&#xff0c;起源于20世纪60年代&#xff0c;是一种解决问题的方法。它不仅仅是设计师的专利&#xff0c;而是一种可以广泛应用于各种行业和领域的方法。设计思维强调了用户至中的重要性&#xff0c;认为任何问题的解决都应该从用户的需求出发。这种方法鼓励我们…

反转链表+交换两个链表的节点

目录 ​编辑 一&#xff0c;反转链表 1.题目描述 2.例子 3.题目接口 4.分析以及解题代码 1.迭代法 2.递归写法 二&#xff0c;两两交换两个链表中的节点 1.题目描述 2.例子 3.题目接口 4.题目分析以及解法 一&#xff0c;反转链表 1.题目描述 首先来看看反转链表的…

主流深度学习框架及神经网络模型汇总

目录 主流深度学习框架及神经网络模型汇总 一、人工智能的研究领域和分支 二、主流深度学习框架​编辑 1.TensorFlow 2.PyTorch 3.PaddlePaddle 4.Keras 5.Caffe/Caffe2 6.MXNet 7.Theano 8.Torch 9.CNTK 10.ONNX 三、深度学习移动端推理框架 1.TensorRT 2.TF-…

LabVIEW是如何控制硬件的?

概述 工程 师 和 科学 家 可以 使用 LabVIEW 与 数千 种 不同 的 硬件 设备 无缝 集成&#xff0c; 并 通过 方便 的 功能 和 跨 所有 硬件 的 一致 编 程 框架 帮助 节省 开发 时间。 内容 通过更简单的系统集成节省开发时间 连接到任何硬件 NI 硬件 第三方硬件 快速找到…

数据库事务四大特性

事务的4大特性&#xff08;ACID&#xff09;&#xff1a; 原子性(Atomicity)&#xff1a; 事务是数据库的逻辑工作单位&#xff0c;它对数据库的修改要么全部执行&#xff0c;要么全部不执行。 一致性(Consistemcy)&#xff1a; 事务前后&#xff0c;数据库的状态都满足所有的完…

Python之defaultdict方法详解

文章目录 字典dict介绍collections.defaultdict类 字典dict介绍 python中的dict是一个重要的数据类型,用“键”(key)来索引&#xff0c;表示为dict(key: val, …),有以下特征&#xff1a; 键可以是任何不可变(immutable)数据类型不可变数据类型有&#xff1a;数字&#xff0c…

嵌入式软件设计

欢迎关注博主 Mindtechnist 或加入【Linux C/C/Python社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和…

手写数字识别之损失函数

目录 交叉熵 手写数字识别之损失函数 分类任务的损失函数 Softmax函数 交叉熵的简单理解&#xff1a;真实分布与非真实分布的交叉&#xff0c;完全对应&#xff0c;熵为0 交叉熵的代码实现 交叉熵 给定一个策略, 交叉熵就是在该策略下猜中颜色所需要的问题的期望值。更普…

三、JVM监控及诊断工具-GUI篇

目录 一、工具概述二、jconsole&#xff08;了解即可&#xff09;1、基本概述2、启动3、三种连接方式4、作用 三、Visual VM 一、工具概述 二、jconsole&#xff08;了解即可&#xff09; 1、基本概述 从Java5开始&#xff0c;在JDK中自带的Java监控和管理控制台用于对JVM中内…

【mindspore学习】环境配置

本次实验搭配的环境是 CUDA 11.6 CUDNN v8.9.4 TensorRT-8.4.1.5 mindspore 2.1.0。 1、配置 Nvidia 显卡驱动 如果原来的主机已经安装了 nvidia 驱动&#xff0c;为避免版本的冲突&#xff0c;建议先清除掉旧的 nvidia驱动 sudo apt-get --purge remove nvidia* sudo apt…

土豆叶病害识别(图像连续识别和视频识别)

效果视频&#xff1a;土豆叶病害识别&#xff08;Python代码&#xff0c;pyTorch框架&#xff0c;视频识别&#xff09;_哔哩哔哩_bilibili 代码运行要求&#xff1a;Torch库>1.13.1&#xff0c;其它库无版本要求 1..土豆叶数据集主要包好三种类别&#xff08;Early_Blight…

分布式训练 最小化部署docker swarm + docker-compose落地方案

目录 背景&#xff1a; 前提条件&#xff1a; 一、docker环境初始化配置 1. 安装nvidia-docker2 2. 安装docker-compose工具 3. 获取GPU UUID 4. 修改docker runtime为nvidia&#xff0c;指定机器的UUID 二、docker-swarm 环境安装 1. 初始化swarm管理节点 2. 加入工…

Redis数据类型全总结【万字总结】

文章目录 前言一、String1、内部实现2、应用场景缓存对象常规计数分布式锁共享 Session 信息 3、常用指令 二、List1、内部实现2、应用场景消息队列List 作为消息队列有什么缺陷 3、常用指令 三、Hash1、内部实现2、应用场景缓存对象购物车 3、常用指令 四、Set1、内部实现2、应…