当前位置: 首页 > news >正文

Android 添加系统服务的完整流程

[应用程序] (应用进程)│↓ 调用简单API
[SoundManager] │   ├─ 代理模式+门面模式(应用进程)│   ├─ 缓存数据 ←─ 装饰器模式(应用进程)│   └─ 转换异常 ←─ 适配器模式(应用进程)│↓ 通过Binder跨进程调用
[Binder Proxy]// 自动生成的Binder代理类(运行在应用进程,但处理跨进程通信)│↓ IPC(跨进程通信)
[SoundManagerService] (SystemServer进程)// 实际服务实现(运行在系统进程)└─ Binder Stub // 自动生成的Stub类(系统进程接收端)






以 Sound 服务为例,展示 Android 系统中添加一个系统服务的完整流程:

1. 定义 AIDL 接口

frameworks/base/core/java/android/media/ 创建接口文件:

// ISoundManager.aidl
package android.media;/** @hide */
interface ISoundManager {void playSound(in String soundName);void setVolume(int volume);int getCurrentVolume();boolean isMuted();
}

2. 实现服务端代码

系统服务的服务端实现(如 ActivityManagerService)通常放在 frameworks/base/services/

frameworks/base/services/core/java/com/android/server/sound/中实现服务:

// SoundManagerService.java
package com.android.server.sound;import android.content.Context;
import android.media.ISoundManager;public class SoundManagerService extends ISoundManager.Stub {private final Context mContext;private int mCurrentVolume = 50;private boolean mMuted = false;public SoundManagerService(Context context) {mContext = context;}@Overridepublic void playSound(String soundName) {enforceSoundPermission();// 实际播放声音的实现}@Overridepublic void setVolume(int volume) {mCurrentVolume = Math.max(0, Math.min(100, volume));}@Overridepublic boolean isMuted() {return mMuted;}private void enforceSoundPermission() {mContext.enforceCallingPermission("android.permission.MANAGE_SOUND","Sound permission required");}
}

3. 在 SystemServer 中启动服务

修改 frameworks/base/services/java/com/android/server/SystemServer.java

// 在 startOtherServices() 方法中添加
traceBeginAndSlog("StartSoundManagerService");
mSystemServiceManager.startService(SoundManagerService.class);
traceEnd();

4. 创建客户端管理器类

面向app开发的接口在frameworks/base/core/java/

存放的是 Android 框架的公共基础代码,主要分为两类:

1.面向应用开发者:提供 App 可调用的 SDK API(如 android.app、android.content)。
2.面向系统内部:实现 Android 核心机制(如 Binder、权限管理),这些对 App 透明,但支撑 App 运行。

frameworks/base/core/java/android/media/ 中创建:

// SoundManager.java
package android.media;import android.content.Context;public class SoundManager {public static final String SERVICE = "sound";private static ISoundManager sService;private final Context mContext;public static SoundManager get(Context context) {if (sService == null) {IBinder b = ServiceManager.getService(SERVICE);sService = ISoundManager.Stub.asInterface(b);}return new SoundManager(context);}private SoundManager(Context context) {mContext = context;}public void playSound(String soundName) {try {sService.playSound(soundName);} catch (RemoteException e) {throw e.rethrowFromSystemServer();}}public int getCurrentVolume() {try {return sService.getCurrentVolume();} catch (RemoteException e) {throw e.rethrowFromSystemServer();}}
}

5. 在 ContextImpl 中注册服务

修改 frameworks/base/core/java/android/app/ContextImpl.java

// 在 static {} 块中添加
registerService(SoundManager.SERVICE, new ServiceFetcher() {@Overridepublic Object createService(ContextImpl ctx) {return SoundManager.get(ctx);}
});

6. 添加权限声明

frameworks/base/core/res/AndroidManifest.xml 中添加:

<permission android:name="android.permission.MANAGE_SOUND"android:protectionLevel="signature" />

7. 更新系统配置

frameworks/base/core/res/res/values/config.xml 中添加:

<bool name="config_soundServiceEnabled">true</bool>

8. 编译和测试

编译系统并测试新服务:

bash
make -j8

9. 应用层调用示例

应用中使用 Sound 服务:

SoundManager soundManager = (SoundManager) getSystemService(Context.SOUND_SERVICE);
soundManager.playSound("notification");
int volume = soundManager.getCurrentVolume();
http://www.xdnf.cn/news/590797.html

相关文章:

  • JavaScript【9】ES语法
  • 阿里云 Serverless 助力海牙湾构建弹性、高效、智能的 AI 数字化平台
  • 新手到资深的Java开发编码规范
  • Python爬虫实战:研究Crawley 框架相关技术
  • 【Java Web】1.Maven
  • Docker常用命令介绍
  • upload-labs靶场通关详解:第14关
  • PyQt学习系列01-框架概述与基础环境搭建
  • 25.5.22学习总结
  • MCP Server Tool 开发学习文档
  • 国产数据库:tidb专题
  • 微信小程序 隐私协议弹窗授权
  • Git分支的强制回滚
  • 辽宁省工程系列信息通信管理专业职称评审标准
  • 国芯思辰| 高精度线性霍尔传感器AH693在角度位置传感器中的应用
  • 【机器学习】欠拟合、过拟合和正则化
  • ARM Linux远程调试
  • day 33简单的神经网络
  • Linux `wc` 命令深度解析与高阶应用指南
  • 计算机网络——Session、Cookie 和 Token
  • Bert预训练任务-MLM/NSP
  • 数仓SQL投影介绍
  • 小米2025年校招笔试真题手撕(一)
  • 基于企业数字化转型战略的数据治理方法论与顶层设计思路
  • 基于B/S架构的质量监督检验报告自动生成管理系统有何亮点?
  • Vue3 打印表格、Element Plus 打印、前端打印、表格导出打印、打印插件封装、JavaScript 打印、打印预览
  • Java使用Collections集合工具类
  • DAY 33 简单的神经网络
  • 软件设计师“面向对象设计”真题考点分析——求三连
  • 深入剖析 Doris 倒排索引(上):原理与应用全解析​