Android核心系统服务:AMS、WMS、PMS 与 system_server 进程解析

news2025/5/18 9:34:21

1. 引言

在 Android 系统中,ActivityManagerService (AMS)WindowManagerService (WMS)PackageManagerService (PMS) 是三个最核心的系统服务,它们分别管理着应用的生命周期、窗口显示和应用包管理。

但你是否知道,这些服务并不是独立进程,而是运行在同一个系统进程——system_server 中?本文将介绍 AMS/WMS/PMS 的核心作用,并深入探讨 system_server 进程的架构,包括它的线程模型和关键组件。


2. AMS、WMS、PMS 的作用

(1)ActivityManagerService (AMS) —— 应用生命周期管理者

AMS 是 Android 的“大管家”,负责:

  • 启动/管理 Activity(如 startActivity() 的底层实现)
  • 管理应用进程(通过 ProcessList 分配进程优先级)
  • 处理 ANR(Application Not Responding)
  • 管理任务栈(TaskStack)(决定 Activity 如何回退)

举例:当你点击一个 App 图标时,AMS 会检查目标 Activity 是否存在,并决定是否创建新进程或复用已有进程。

(2)WindowManagerService (WMS) —— 窗口管理者

WMS 负责所有 UI 窗口的显示与交互:

  • 管理窗口层级(Window层级,如 Dialog、Toast、StatusBar)
  • 处理触摸事件分发(决定哪个窗口接收事件)
  • 与 SurfaceFlinger 协作(控制 Surface 的合成与渲染)

举例:当你滑动屏幕时,WMS 会计算触摸事件应该分发给哪个 App 的哪个窗口。

(3)PackageManagerService (PMS) —— 包管理专家

PMS 管理所有 APK 的安装、卸载和权限:

  • 解析 AndroidManifest.xml(获取四大组件信息)
  • 管理应用权限(如运行时权限 checkSelfPermission()
  • 处理 APK 安装/卸载(调用 installd 守护进程)

举例:当你安装一个 App 时,PMS 会校验签名、分配 UID,并更新 /data/system/packages.xml


3. system_server 进程:Android 系统服务的“大本营”

AMS、WMS、PMS 并不是独立进程,而是运行在 system_server 进程中的不同线程

(1)system_server 是什么?

  • Zygote 进程孵化(Android 所有进程的父进程)。
  • 在系统启动时初始化,运行几乎所有核心系统服务。
  • 通过 Binder IPC 向 App 进程提供跨进程调用(如 IActivityManager)。

(2)AMS/WMS/PMS 是 system_server 的线程吗?

是的!system_server 是一个多线程进程,不同的服务运行在不同的线程中:

  • AMSActivityManager 线程
  • WMSWindowManager 线程
  • PMSPackageManager 线程

它们通过 Binder 线程池(如 Binder:XXX_1)与 App 进程通信。

(3)system_server 还有哪些关键线程?

除了 AMS/WMS/PMS,system_server 还包含许多重要线程:

线程名作用
mainSystemServer 主线程,负责启动其他服务
android.fg处理前台任务(如广播、ANR 监测)
android.ui处理 UI 相关任务(如 Input 事件)
android.io管理 I/O 操作(如文件读写)
Binder:XXX_NBinder 线程池,处理跨进程调用

示例:当 App 调用 startActivity() 时:

  1. App 进程通过 Binder 调用 system_serverActivityManager 线程。
  2. AMS 处理请求后,可能再通过 WMS 的 WindowManager 线程管理窗口。

4. 为什么这样设计?—— 多线程 vs 多进程

你可能会有疑问:为什么不把 AMS、WMS、PMS 拆分成独立进程?

(1)性能考量

  • 减少进程间通信(IPC)开销:如果 AMS/WMS/PMS 是独立进程,每次调用都需要 Binder 通信,而 Binder 是同步阻塞的,频繁 IPC 会降低性能。
  • 共享内存优化:同进程内数据共享更快(如 ActivityRecordWindowState 等数据结构)。

(2)稳定性与依赖管理

  • AMS/WMS/PMS 之间需要紧密协作(如启动 Activity 需要 AMS 和 WMS 配合)。
  • 如果某个服务崩溃,整个 system_server 会重启(而不是单个服务崩溃导致系统不稳定)。

(3)历史演进

  • 早期 Android 确实尝试过让部分服务独立(如 SurfaceFlinger),但后来发现 IPC 开销太大,最终大多数核心服务合并到 system_server

5. 如何观察 system_server 的线程?

我们可以通过以下命令查看 system_server 的线程情况:

# 查看 system_server 进程ID
adb shell ps -A | grep system_server

# 查看该进程的所有线程
adb shell ps -T <PID>

# 或者用 top 看 CPU 占用
adb shell top -H -p <PID>

典型输出示例

USER      PID   PPID  TID   CMD  
system    1234  1     1234  system_server  
system    1234  1     1235  Binder:1234_1  
system    1234  1     1236  ActivityManager  
system    1234  1     1237  WindowManager  
system    1234  1     1238  PackageManager  

6. 总结

  1. AMS/WMS/PMS 是 Android 最核心的三大系统服务,分别管理应用、窗口和包。
  2. 它们运行在 system_server 进程的不同线程,而非独立进程,以减少 IPC 开销。
  3. system_server 是一个多线程进程,包含主线程、Binder 线程、AMS/WMS/PMS 专属线程等。
  4. 这样设计的优势:性能高、协作方便、稳定性强。

如果你是 Android 开发者,理解 system_server 的架构,能帮助你更深入地掌握 Framework 层的工作原理,尤其是在分析 ANR、UI 卡顿、Binder 通信等问题时。


7. 扩展思考

  • 如果 AMS 的线程卡死,会影响 WMS 吗?(答案:会,因为它们同属 system_server 进程!)
  • 为什么 SurfaceFlinger 不在 system_server 里?(答案:因为它需要独立的 GPU 访问权限,且历史原因。)
  • 如何优化 system_server 的负载?(答案:减少跨进程调用、避免主线程阻塞。)

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

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

相关文章

NBA足球赛事直播源码体育直播M33模板赛事源码

源码名称&#xff1a;体育直播赛事扁平自适应M33直播模板源码 开发环境&#xff1a;帝国cms7.5 空间支持&#xff1a;phpmysql 带软件采集&#xff0c;可以挂着自动采集发布&#xff0c;无需人工操作&#xff01; 演示地址&#xff1a;NBA足球赛事直播源码体育直播M33模板赛事…

电子电器架构 --- 整车造车阶段四个重要节点

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 钝感力的“钝”,不是木讷、迟钝,而是直面困境的韧劲和耐力,是面对外界噪音的通透淡然。 生活中有两种人,一种人格外在意别人的眼光;另一种人无论…

黑马点评-用户登录

文章目录 用户登录发送短信验证码注册/登录校验登录 用户登录 发送短信验证码 public Result sendCode(String phone, HttpSession session) {// 1.校验手机号if (RegexUtils.isPhoneInvalid(phone)) {// 2.如果不符合&#xff0c;返回错误信息return Result.fail("手机…

十二、Hive 函数

作者&#xff1a;IvanCodes 日期&#xff1a;2025年5月1日 专栏&#xff1a;Hive教程 在数据处理的广阔天地中&#xff0c;我们常常需要对数据进行转换、计算、清洗或提取特定信息。Hive 提供了强大的内置运算符和丰富的内置函数库&#xff0c;它们就像魔法师手中的魔法棒&…

No More Adam: 新型优化器SGD_SaI

一.核心思想和创新点 2024年12月提出的SGD-SaI算法&#xff08;Stochastic Gradient Descent with Scaling at Initialization&#xff09;本质上是一种在训练初始阶段对不同参数块&#xff08;parameter block&#xff09;基于**梯度信噪比&#xff08;g-SNR, Gradient Signa…

JSP链接MySQL8.0(Eclipse+Tomcat9.0+MySQL8.0)

所用环境 Eclipse Tomcat9.0 MySQL8.0.21(下载&#xff1a;MySQL Community Server 8.0.21 官方镜像源下载 | Renwole&#xff09; mysql-connector-java-8.0.21&#xff08;下载&#xff1a;MySQL :: Begin Your Download&#xff09; .NET Framework 4.5.2&#xff08;下…

SEO长尾词与关键词优化实战

内容概要 在SEO优化体系中&#xff0c;长尾关键词与核心关键词的协同作用直接影响流量获取效率与用户转化路径。长尾词通常由3-5个词组构成&#xff0c;搜索量较低但意图明确&#xff0c;能精准触达细分需求用户&#xff1b;核心关键词则具备高搜索量与广泛覆盖能力&#xff0…

机器学习-人与机器生数据的区分模型测试-数据处理1

附件为训练数据&#xff0c;总体的流程可以作为参考。 导入依赖 import pandas as pd import os import numpy as np from sklearn.model_selection import train_test_split,GridSearchCV from sklearn.ensemble import RandomForestClassifier,VotingClassifier from skle…

HelloWorld

HelloWorld 新建一个java文件 文件后缀名为 .javahello.java【注意】系统可能没有显示文件后缀名&#xff0c;我们需要手动打开 编写代码 public class hello {public static void main(String[] args) {System.out.print(Hello,World)} }编译 javac java文件&#xff0c;会生…

SEO 优化实战:ZKmall模板商城的 B2C商城的 URL 重构与结构化数据

在搜索引擎算法日益复杂的今天&#xff0c;B2C商城想要在海量信息中脱颖而出&#xff0c;仅靠优质商品和营销活动远远不够。ZKmall模板商城以实战为导向&#xff0c;通过URL 重构与结构化数据优化两大核心策略&#xff0c;帮助 B2C 商城实现从底层架构到搜索展示的全面升级&…

数字万用表与指针万用表使用方法及注意事项

在电子测量领域&#xff0c;万用表是极为常用的工具&#xff0c;数字万用表和指针万用表各具特点。熟练掌握它们的使用方法与注意事项&#xff0c;能确保测量的准确性与安全性。下面为您详细介绍&#xff1a; 一 、数字万用表按钮功能 > 进入及退出手动量程模式 每 按 […

【读代码】端到端多模态语言模型Ultravox深度解析

一、项目基本介绍 Ultravox是由Fixie AI团队开发的开源多模态大语言模型,专注于实现音频-文本的端到端实时交互。项目基于Llama 3、Mistral等开源模型,通过创新的跨模态投影架构,绕过了传统语音识别(ASR)的中间步骤,可直接将音频特征映射到语言模型的高维空间。 核心优…

RabbitMQ工作流程及使用方法

一、什么是RabbitMQ RabbitMQ 是一款基于 ‌AMQP&#xff08;高级&#xff0c;消息队列协议&#xff09;‌ 的开源消息中间件&#xff0c;专为分布式系统设计&#xff0c;用于实现应用程序间的异步通信&#xff0c;其核心功能是通过 ‌消息代理&#xff08;Message Broker&…

算法:分治法

实验内容 在一个2kⅹ2k个方格组成的棋盘中&#xff0c;若恰有一个方格与其他方格不同&#xff0c;则称该方格为特殊方格&#xff0c;且称该棋盘为一特殊棋盘。 显然&#xff0c;特殊方格出现的位置有4k 种情况&#xff0c;即k>0,有4k 种不同的特殊棋盘 棋盘覆盖&#xff1a…

MySQL初阶:sql事务和索引

索引&#xff08;index&#xff09; 可以类似理解为一本书的目录&#xff0c;一个表可以有多个索引。 索引的意义和代价 在MySQL中使用select进行查询时会经过&#xff1a; 1.先遍历表 2.将条件带入每行记录中进行判断&#xff0c;看是否符合 3.不符合就跳过 但当表中的…

docker部署第一个Go项目

1.前期准备 目录结构 main.go package mainimport ("fmt""github.com/gin-gonic/gin""net/http" )func main() {fmt.Println("\n .::::.\n .::::::::.\n :::::::::::\n …

Visual Studio2022跨平台Avalonia开发搭建

由于我已经下载并安装了 VS2022版本&#xff0c;这里就跳过不做阐述。 1.安装 Visual Studio 2022 安装时工作负荷Tab页勾选 ‌“.NET 桌面开发”‌ 和“Visual Studio扩展开发”‌ &#xff0c;这里由于不是用的微软的MAUI&#xff0c;所以不用选择其他的来支持跨平台开发&a…

css iconfont图标样式修改,js 点击后更改样式

背景&#xff1a; 在vue项目中&#xff0c;通过点击/鼠标覆盖&#xff0c;更改选中元素的样式&#xff0c;可以通过js逻辑&#xff0c;也可以根据css样式修改。包括以下内容&#xff1a;iconfont图标的引入以及使用&#xff0c;iconfont图标样式修改【导入文件是纯白&#xff0…

开源项目实战学习之YOLO11:12.4 ultralytics-models-sam-memory_attention.py源码分析

👉 点击关注不迷路 👉 点击关注不迷路 👉 另外,前些天发现了一个巨牛的AI人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。感兴趣的可以点击相关跳转链接。 点击跳转到网站。 ultralytics-models-sam 1.sam-modules-memory_attention.pyblocks.py: 定义模…

【沉浸式求职学习day42】【算法题:滑动窗口】

沉浸式求职学习 长度最小的子数组水果成篮 关于算法题&#xff1a;滑动窗口的几个题目 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 s &#xff0c;找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组&#xff0c;并返回其长度。如果不存在符合条件的子数组…