Zygote System Server app

2024-04-09 19:48
文章标签 app system server zygote

本文主要是介绍Zygote System Server app,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Zygote & System Server & App


init进程:

  1. 进程pid为1
  2. Linux系统中,用户空间第一个进程。(内核空间存放内核代码 和 数据, 用户空间存放用户程序的代码和数据)
  3. 父进程pid为0,系统内核空间。
  4. 内核启动之后,执行的第一个进程。

Zygote:

时序图:


app_main.cpp


AndroidRuntime.cpp


ZygoteInit


runSelectLoop:


作用:

  1. Zygote负责fork其他的Android(Java 层)进程:所有的应用程序进程 ,SystemServer。
  2. 提供共享资源:FrameWork共享类 及 共享资源。(zygote提供了同一段物理内存空间用来存储共享数据)

谁启动的Zygote:

由Android系统的第一个进程init启动。(init 进程是在内核加载完成之后就启动起来的)

关于Zygote:

  1. 是安卓运行的第一个Dalvik虚拟机进程。
  2. /System/bin/app_process 是Zygote进程对应的应用程序文件。
  3. SystemServer 和 Zygote分属android操作系统不同Davik虚拟机上运行的不同进程。
  4. app_process的本质就是 使用dalvikvm启动ZygoteInit.java,并在启动后加载Framework中的大部分类和资源。
  5. 虚拟机执行的第一个java类是ZygoteInit.java类。接下来的过程从ZygoteInit的main方法开始。
  6. ZygoteInit main方法第一个重要工作就是启动一个Socket 服务端,该Socket端口是为了接收启动新进程的命令。
  7. ZygoteInit 的main方法创建好Socket服务端后,不能马上fork新进程。还需要预装FrameWork的大部分类和资源。
  8. preload-resources包括两类资源: drawable资源 和 color资源。
  9. ActivityManagerService 在请求Zygote进程创建新进程时,会首先打开/dev/socket/zygote 这个设备文件来创建一个连接到Zygote进程的Client端的socket。

由Zygote进程fork新的程序

  1. SystemServer和Zygote通过Socket进行跨进程通信。
  2. SystemServer持有Socket客户端。
  3. Zygote持有Socket服务端。
  4. fork新的davilk进程命令由SystemServer首先发起,利用SystemServer的socket客户端发出fork新davilk进程的命令,Zygote进程的Socket服务端收到,并fork新进程程序。


SystemServer

时序图


作用

  1. apk应用中能够直接交互的大部分系统服务都在这个进程中运行。
  2. AMS,WMS,PMS这些系统服务都是以一个线程的方式存在于SystemServer进程中。

与Zygote关系

  1. SystemServer进程是由zygote fork出来的第一个进程。
  2. SystemServer进程是从ZygoteInit.java的main方法中调用startSystemServer开始的。
  3. SystemServer 与 Zygote 使用Socket进行跨进程通信。(SystemServer 有一个Socket客户端,Zygote有Socket服务端负责接收fork请求)
  4. 在SystemServer进程中会创建一个Socket客户端,具体的实现代码是在Process.java中。

何时启动Launcher

在System Server加载startOthersService后,调用ActivityManagerService.systemReady方法执行的startHomeActivityLocaked的。

ActivityManagerService

作用:

  1. 主要负责管理Activity,兼职管理Android系统的内存和进程。

Activity 与

App & SystemServer & zygote 进程的IPC方式


app进程调用 :通过


ActivityManagerService对app的调用

App 到 AMS进行通信时,需要先得到ActivityManagerProxy。如何得到呢?AMS到App进行通信时,需要先得到ApplicationThreadProxy,又是如何得到的?



通过上面的代码,我们得知,双方是如何对对方进行调用的。

ApplicationThread 与 ActivityThread的关系

从上面的代码可知,ApplicationThread是ActivityThread的内部类,所以其可以对ActivityThread进行调用。

App a 进程 启动App b 的过程



ActivityThread类

ActivityThread 并非继承自Thread


程序的入口:zygote当进程启动的时候,zygote会调用ActivityThread的 main方法。

main方法


第一件事:

  1. 创建当前进程的ActivityThread对象。
  2. 调用其attach方法,把当前进程与AMS(System Server)进程建立关系(传递当前进程的AppliationThreadProxy给AMS进程)。与AMS建立了关系之后,AMS再通过ApplicationThreadProxy调用bindApplication,来创建Application对象
  3. 来自AMS的bindApplication方法创建了Application对象,并且调用了Application的onCreate方法

第二件事:

  1. 开启loop循环。用来接收、分发app 主线程的消息事件。如触摸事件的处理。

作用

  1. 一个apk的入口类是ActivityThread
  2. 开启主线程的loop,给消息传递、分发提供支持。

ActivityThread的handleLaunchActivity方法


  1. 执行perfromLaunchActivity:执行Activity的创建、attach 和 onCreate回调作用。
  2. handleResumeActivity:执行Activity的onResume操作。

ActivityThread的performLaunchActivity方法


做了几件事

  1. 创建Activity的实例。
  2. 创建ContextImpl对象
  3. 执行Activity的attach方法 :  把ContextImpl对象传递给Activity。
  4. 执行Activity的onCreate方法。

1.使用Instrumentation创建Activity实例。

2.创建ContextImpl 对象

ContextImpl类

3.执行Activity的attach方法


attachBaseContext做了什么?把ContextImpl的实例赋值为ContextWrapper的一个引用。

ContextWrapper实际真正调用的是ContextImpl的实例


4.使用Instrumentation,调用Activity的onCreate方法。


其他

  1. 在Linux系统中,所有的资源文件都可以看成文件,甚至包括 CPU 和 内存。标准的磁盘文件或者网络Socket也被认为是文件。
  2. 在SystemServer进程中会创建一个Socket客户端,具体的实现代码是在Process.java中。
  3. fork:linux系统中的一个系统调用,其功能是复制当前进程并产生一个新的进程。
  4. 内核(kernel) 利用 文件描述符(file descriptor) 来访问文件。(文件描述符是 非负整数)读写文件需要使用文件描述符来指定待读写的文件。



这篇关于Zygote System Server app的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/889048

相关文章

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

macOS怎么轻松更换App图标? Mac电脑图标更换指南

《macOS怎么轻松更换App图标?Mac电脑图标更换指南》想要给你的Mac电脑按照自己的喜好来更换App图标?其实非常简单,只需要两步就能搞定,下面我来详细讲解一下... 虽然 MACOS 的个性化定制选项已经「缩水」,不如早期版本那么丰富,www.chinasem.cn但我们仍然可以按照自己的喜好来更换

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

SQL Server数据库磁盘满了的解决办法

《SQLServer数据库磁盘满了的解决办法》系统再正常运行,我还在操作中,突然发现接口报错,后续所有接口都报错了,一查日志发现说是数据库磁盘满了,所以本文记录了SQLServer数据库磁盘满了的解... 目录问题解决方法删除数据库日志设置数据库日志大小问题今http://www.chinasem.cn天发

Partical System

创建"粒子系统物体"(点击菜单GameObject -> Create Other -> Particle System) 添加"粒子系统组件"(点击Component -> Effects  ->Particle System) 粒子系统检视面板  点击粒子系统检视面板的右上角的"+"来增加新的模块。(Show All Modules:显示全部) 初始化模块: •

red5-server源码

red5-server源码:https://github.com/Red5/red5-server

小技巧绕过Sina Visitor System(新浪访客系统)

0x00 前言 一直以来,爬虫与反爬虫技术都时刻进行着博弈,而新浪微博作为一个数据大户更是在反爬虫上不遗余力。常规手段如验证码、封IP等等相信很多人都见识过…… 当然确实有需要的话可以通过新浪开放平台提供的API进行数据采集,但是普通开发者的权限比较低,限制也比较多。所以如果只是做一些简单的功能还是爬虫比较方便~ 应该是今年的早些时候,新浪引入了一个Sina Visitor Syst

System.getProperties().

Java.version Java 运行时环境版本 java.vendor Java 运行时环境供应商 java.vendor.url Java 供应商的 URL java.home Java 安装目录 java.vm.specification.version Java 虚拟机规范版本 java.vm.specification.vendor

MFC中App,Doc,MainFrame,View各指针的互相获取

纸上得来终觉浅,为了熟悉获取方法,我建了个SDI。 首先说明这四个类的执行顺序是App->Doc->Main->View 另外添加CDialog类获得各个指针的方法。 多文档的获取有点小区别,有时间也总结一下。 //  App void CSDIApp::OnApp() {      //  App      //  Doc     CDocument *pD

安装SQL2005后SQL Server Management Studio 没有出来的解决方案

一种情况,在安装 sqlServer2005 时 居然出现两个警告: 1 Com+ 目录要求 2 Edition change check 郁闷!网上说出现两个警告,是肯定装不成功的!我抱着侥幸的态度试了下,成功了。 安装成功后,正准备 “ 仅工具、联机丛书和示例(T)” 但是安装不了,他提示我“工作站组件”安装过了对现有组件无法更新或升级。 解决办法: 1 打开“控