今天导师给我将讲了一些如何新建一个系统服务,以及如何去初始化。

Android SystemServer 中 Service 的创建和启动方式

在 Android 系统中,SystemServer 是系统服务的核心进程,负责启动和管理各种系统服务。以下是 SystemServer 中服务创建和启动的详细方式:

1. SystemServer 概述

SystemServer 是 Android 系统启动过程中的关键组件,它运行在 system_server 进程中,负责启动和管理所有核心系统服务。

2. 服务启动流程

2.1 主要启动阶段

SystemServer 的服务启动分为几个主要阶段:

// frameworks/base/services/java/com/android/server/SystemServer.java
private void run() {// 1. 启动引导服务 (Bootstrap Services)startBootstrapServices();// 2. 启动核心服务 (Core Services)startCoreServices();// 3. 启动其他服务 (Other Services)startOtherServices();// 4. 系统就绪后的回调startSystemUi(context);systemReady();
}

2.2 引导服务启动

// frameworks/base/services/java/com/android/server/SystemServer.java
private void startBootstrapServices() {// 启动 ActivityManagerServicemActivityManagerService = ActivityManagerService.Lifecycle.startService(mSystemServiceManager, atm);mActivityManagerService.setSystemProcess();// 启动 PowerManagerServicemPowerManagerService = mSystemServiceManager.startService(PowerManagerService.class);// 启动 PackageManagerServicemPackageManagerService = PackageManagerService.main(mSystemContext, installer,mFactoryTestMode != FactoryTest.FACTORY_TEST_OFF, mOnlyCore);// 更多引导服务...
}

2.3 核心服务启动

private void startCoreServices() {// 启动 BatteryServicemSystemServiceManager.startService(BatteryService.class);// 启动 UsageStatsServicemSystemServiceManager.startService(UsageStatsService.class);mActivityManagerService.setUsageStatsManager(LocalServices.getService(UsageStatsManagerInternal.class));// 启动 WebViewUpdateServicemWebViewUpdateService = mSystemServiceManager.startService(WebViewUpdateService.class);// 更多核心服务...
}

2.4 其他服务启动

private void startOtherServices() {// 启动 WindowManagerServicewm = WindowManagerService.main(context, inputManager, !mFirstBoot, mOnlyCore,new PhoneWindowManager(), mActivityManagerService.mActivityTaskManager);ServiceManager.addService(Context.WINDOW_SERVICE, wm, /* allowIsolated= */ false);ServiceManager.addService(Context.INPUT_SERVICE, inputManager);// 启动 NotificationManagerServicemSystemServiceManager.startService(NotificationManagerService.class);// 启动自定义服务(如你的 MDM 服务)try {traceBeginAndSlog("StartMdmPolicyManager");mdmPolicyManager = new MdmPolicyManagerService(context);ServiceManager.addService(Context.MDM_POLICY_SERVICE, mdmPolicyManager);traceEnd();} catch (Throwable e) {reportWtf("starting Mdm Policy Manager", e);}// 更多其他服务...
}

3. 服务创建方式

3.1 使用 SystemServiceManager 启动

这是推荐的方式,适用于继承自 SystemService 的服务:

// 在 SystemServer 中
mSystemServiceManager.startService(YourService.class);// 服务类定义
public class YourService extends SystemService {public YourService(Context context) {super(context);}@Overridepublic void onStart() {// 服务启动逻辑publishBinderService(Context.YOUR_SERVICE, new YourBinder());}@Overridepublic void onBootPhase(int phase) {if (phase == SystemService.PHASE_BOOT_COMPLETED) {// 启动完成后的操作}}
}

3.2 直接实例化并注册

对于不继承 SystemService 的服务:

// 创建服务实例
YourService yourService = new YourService(context);// 添加到 ServiceManager
ServiceManager.addService(Context.YOUR_SERVICE, yourService);// 或者使用带权限的添加方式
ServiceManager.addService(Context.YOUR_SERVICE, yourService, false, ServiceManager.DUMP_FLAG_PRIORITY_DEFAULT);

3.3 使用静态 main 方法

某些服务有静态的 main() 方法:

// 服务类中的静态方法
public static YourService main(Context context) {YourService service = new YourService(context);ServiceManager.addService(Context.YOUR_SERVICE, service);return service;
}// 在 SystemServer 中调用
YourService.main(mSystemContext);

4. 服务生命周期管理

4.1 启动阶段(Boot Phases)

系统服务可以在不同的启动阶段执行初始化:

public class YourService extends SystemService {// ...@Overridepublic void onBootPhase(int phase) {if (phase == PHASE_THIRD_PARTY_APPS_CAN_START) {// 第三方应用可以启动时的初始化} else if (phase == PHASE_BOOT_COMPLETED) {// 系统启动完成后的操作}}
}

4.2 系统就绪回调

private void systemReady() {// 通知所有服务系统已就绪mActivityManagerService.systemReady(() -> {// 系统就绪后的操作}, BOOT_TIMINGS_TRACE_LOG);
}

5. 自定义服务示例

以下是在 SystemServer 中添加自定义服务的完整示例:

5.1 服务接口定义 (AIDL)

// frameworks/base/core/java/android/app/IMyCustomService.aidl
package android.app;interface IMyCustomService {void doSomething(int param);int getSomething();
}

5.2 服务实现

// frameworks/base/services/core/java/com/android/server/MyCustomService.java
package com.android.server;import android.app.IMyCustomService;
import android.content.Context;
import android.os.IBinder;
import android.util.Slog;public class MyCustomService extends IMyCustomService.Stub {private static final String TAG = "MyCustomService";private final Context mContext;public MyCustomService(Context context) {mContext = context;Slog.i(TAG, "MyCustomService created");}@Overridepublic void doSomething(int param) {Slog.d(TAG, "doSomething called with param: " + param);// 实现具体功能}@Overridepublic int getSomething() {Slog.d(TAG, "getSomething called");return 42; // 示例返回值}
}

5.3 在 SystemServer 中启动服务

// frameworks/base/services/java/com/android/server/SystemServer.java
public final class SystemServer {// ...private void startOtherServices() {// ...// 启动自定义服务try {traceBeginAndSlog("StartMyCustomService");MyCustomService myCustomService = new MyCustomService(context);ServiceManager.addService(Context.MY_CUSTOM_SERVICE, myCustomService);traceEnd();} catch (Throwable e) {reportWtf("starting My Custom Service", e);}// ...}
}

5.4 在 Context 中定义服务常量

// frameworks/base/core/java/android/content/Context.java
public abstract class Context {// ...public static final String MY_CUSTOM_SERVICE = "my_custom_service";// ...
}

6. 注意事项

  1. 启动顺序:服务的启动顺序很重要,依赖其他服务的服务应该在依赖服务之后启动
  2. 异常处理:使用 try-catch 块捕获服务启动过程中的异常
  3. 性能考虑:避免在服务启动过程中执行耗时操作
  4. 权限控制:确保服务有适当的权限检查
  5. 进程间通信:如果服务需要跨进程访问,确保正确实现 Binder 接口

7. 调试技巧

  1. 使用 dumpsys 命令检查服务状态:

    adb shell dumpsys my_custom_service
    
  2. 查看服务列表:

    adb shell service list
    
  3. 检查系统日志:

    adb logcat -s SystemServer
    

通过以上方式,你可以在 Android SystemServer 中成功创建和启动自定义系统服务。

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL SERVER中位数

有11家门店数据,要求每天所有门店的各个指标的中位数1.第一种做法,使用PERCENTILE_CONT() 函数 SQL SERVER 2012 版本及以上PERCENTILE_CONT 函数简介PERCENTILE_CONT 是 SQL 中的窗口函数,用于计算连续百分位数&#…

【java中springboot引入geotool】

学习目标: 在Spring Boot项目中引入GeoTools库,可以按照以下步骤进行:理解GeoTools库的基本信息和用途 GeoTools是一个开源的Java库,用于处理地理信息系统(GIS)数据。它提供了对空间数据的读取、写入、查询…

多项目开发环境:如何使用update-alternatives管理多版本Java JDK?(Windows、Mac、Ubuntu)

如何使用update-alternatives管理多版本Java JDK?(Windows、Mac、Ubuntu) 📖 摘要 在实际开发中,往往会遇到既要维护老项目又要跟进新特性的场景,这就需要在一台机器上同时安装并切换多个Java JDK版本。本…

力扣57:插入区间

力扣57:插入区间题目思路代码题目 给你一个 无重叠的 ,按照区间起始端点排序的区间列表 intervals,其中 intervals[i] [starti, endi] 表示第 i 个区间的开始和结束,并且 intervals 按照 starti 升序排列。同样给定一个区间 newInterval […

KVM虚拟化技术解析:从企业应用到个人创新的开源力量

1 .KVM:开源虚拟化的核心引擎 KVM(Kernel-based Virtual Machine)作为Linux内核原生集成的开源虚拟化模块,彻底改变了现代数据中心的虚拟化格局。它通过将Linux内核转变为Type-1型虚拟机监控器(Hypervisor)…

28.Linux :通过源代码编译安装lamp

Linux :通过源代码编译安装lamp 区别特性源代码编译安装yum 安装安装方式从源代码编译构建预编译的二进制包自定义程度高度可定制有限定制性能优化可针对特定硬件优化通用优化依赖管理手动解决依赖关系自动解决依赖安装复杂度复杂,需技术经验简单&#x…

应用控制技术

一、 应用特征识别技术1.传统行为检测技术1.1 五元组检测原理1.2 配置思路1.3 效果展示需求背景21.4 传统行为检测的缺陷无法识别应用层内容:若应用更换端口(如QQ改用随机端口)或伪装协议(如HTTPS加密),传统…

当MySQL的int不够用了

关于int的长度很多时候看到int(8)这样的定义,其实这是工具导出的不专业。int是范围,不是长度。在开发有了共识(知道这个长度不算数,要看范围)以后,上来就是所有的类型都是bigint。int的范围int的取值范围是…

让AI学会“边做边想“:ReAct的实战指南

小智的求职困境有个叫小智的AI助手,它刚从"大语言模型大学"毕业,满怀信心地去应聘一家咨询公司的智能助理职位。面试官问:"北京和上海哪个城市人口更多?"小智立刻回答:"根据我的知识&#xf…

vue优化有哪些手段?

vue本身存在的方法 v-if 和v-show 的合理运用,频繁使用的组件使用v-show,不频繁的使用v-if,来减少dom的渲染路由懒加载 采用()>import(index.vue)当路由被访问的时候才回去加载使用keep-alive缓存页面,减少没必要的重复渲染同时也可以减少服务器的压力使用computed缓存数据,…

【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)

摘要: 裂缝是结构健康的重要隐患,传统人工巡检耗时耗力且易遗漏。本文将带您利用当前最先进的YOLO12实例分割模型,构建一个高效、准确、更高精度的裂缝检测系统。我们将从数据准备、模型训练到结果可视化,手把手实现一个完整的项目…

“让机器人更智慧 让具身体更智能”北京世界机器人大会行业洞察

2025年8月8日,世界机器人大会在北京盛大开幕。本届大会以“让机器人更智慧 让具身体更智能”为主题,由中国电子学会、世界机器人合作组织主办,包括开幕式、闭幕式、论坛等。同期举办世界机器人博览会、世界机器人大赛等活动,打造了…

PHP如何使用JpGraph生成折线图?

JpGraph是一个功能强大的PHP图表库,它通过封装GD库函数,为开发者提供了简单高效的数据可视化解决方案。作为专门用于绘制统计图的面向对象库,JpGraph支持创建折线图、柱状图、饼图等20余种图表类型,并能自动处理坐标轴、刻度、图例…

超级云平台:重构数字生态的“超级连接器“

在数字经济浪潮席卷全球的今天,企业数字化转型已从"选择题"变为"必答题"。然而,传统云服务模式因技术壁垒高、资源分散、协同效率低等问题,让许多企业在数字化转型中陷入"上云易、用云难"的困境。 在此背景下,一种以"全域资源整合+智能…

https如何保证传递参数的安全

HTTPS 并非直接“加密参数”,而是通过一整套加密传输机制,确保客户端与服务器之间所有通信内容(包括 URL 参数、表单数据、Cookie 等)在传输过程中不被窃听、篡改或伪造。其核心安全保障来自以下技术实现: 一、核心加密…

OpenHarmony之打造全场景智联基座的“分布式星链 ”WLAN子系统

1. 技术架构概览 无线局域网(Wireless Local Area Networks,WLAN),是通过无线电、红外光信号或者其他技术发送和接收数据的局域网,用户可以通过WLAN实现结点之间无物理连接的网络通讯。常用于用户携带可移动终端的办公、公众环境中。 WLAN组件子系统为用户提供WLAN基础功…

JMeter(入门篇)

一.简介 JMeter 是 Apache 组织使用 Java 开发的一款测试工具。 1、可以用于对服务器、网络或对象模拟巨大的负载 2、通过创建带有断言的脚本来验证程序是否能返回期望的结果 二.优缺点 优点: 开源、免费 跨平台 支持多协议 小巧 功能强大 缺点&#xff…

Lecture 12: Concurrency 5

回顾:并行用餐哲学家读者/作者问题哲学家进餐问题方案三:最大化并行需要一个更复杂的解决方案来实现最大的并行性 解决方案使用:state[N]:每个哲学家的当前状态(THINKING, HUNGRY, EATING&#…

UniApp 微信小程序之间跳转指南

概述 在UniApp开发中,经常需要实现从当前小程序跳转到其他微信小程序的功能。本文档详细介绍了如何在UniApp中实现微信小程序之间的跳转。 核心API uni.navigateToMiniProgram() 这是UniApp提供的用于跳转到其他微信小程序的核心API。 基本语法 uni.navigateToMiniP…

基于SpringBoot+Vue的养老院管理系统的设计与实现 智能养老系统 养老架构管理 养老小程序

🔥作者:it毕设实战小研🔥 💖简介:java、微信小程序、安卓;定制开发,远程调试 代码讲解,文档指导,ppt制作💖 精彩专栏推荐订阅:在下方专栏&#x1…