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

Android系统通知机制深度解析:Framework至SystemUI全链路剖析

1. 前言

在Android 13的ROM定制化开发中,系统通知机制作为用户交互的核心组件,其实现涉及Framework层到SystemUI的复杂协作。本文将深入剖析从Notification发送到呈现的全链路流程,重点解析关键类的作用机制及系统服务间的交互逻辑,为系统级定制开发提供理论支撑。

2. 核心架构与关键类解析

2.1 通知机制三级架构模型

  1. 应用层接口:NotificationManager

  2. 系统服务层:NotificationManagerService(NMS)

  3. 呈现控制层:SystemUI/NotificationListener

2.2 核心类职责分解

类名职责范围关键特性
NotificationManager应用级通知API入口Binder代理,线程安全
NotificationManagerService系统通知中枢服务跨进程通信,权限控制,存储管理
NotificationListenerSystemUI通知事件处理异步回调,UI线程同步

3. Framework层通知发送流程深度剖析

3.1 NotificationManager预处理机制

java

复制

// 核心代码路径:frameworks/base/core/java/android/app/NotificationManager.javapublic void notifyAsUser(String tag, int id, Notification notification, UserHandle user) {final INotificationManager service = getService();final Notification processedNotif = fixNotification(notification);service.enqueueNotificationWithTag(...);
}private Notification fixNotification(Notification n) {// 关键预处理步骤:// 1. 图标资源修复(适配不同DPI设备)// 2. 音效URI规范化(跨用户访问控制)// 3. 图像尺寸优化(防止OOM)// 4. 权限校验(FOREGROUND_SERVICE等特殊类型)return Builder.maybeCloneStrippedForDelivery(n);
}

预处理关键点

  • 多用户环境适配(UserHandle)

  • 资源合法性校验(SmallIcon必检)

  • 跨版本兼容处理(targetSdkVersion策略)

3.2 NotificationManagerService处理流程

java

复制

// 代码路径:frameworks/base/services/core/java/com/android/server/notification/NotificationManagerService.javavoid enqueueNotificationInternal(...) {// 构造状态栏通知对象StatusBarNotification sbn = new StatusBarNotification(...);NotificationRecord r = new NotificationRecord(...);// 关键处理步骤:// 1. 前台服务通知优先级提升(IMPORTANCE策略)// 2. PendingIntent白名单管理(DeviceIdleController协作)// 3. 通知渠道状态更新(Channel重要性动态调整)mHandler.post(new EnqueueNotificationRunnable(userId, r));
}class EnqueueNotificationRunnable implements Runnable {public void run() {// 异步处理保证主线程不阻塞mRankingHelper.extractSignals(r);scheduleTimeoutLocked(r);mListeners.notifyPostedLocked(r, old);}
}

服务端处理要点

  • 异步队列管理(Handler+Post机制)

  • 信号量提取(RankingHelper排序策略)

  • 超时控制(scheduleTimeoutLocked防通知堆积)

4. SystemUI通知处理机制

4.1 通知监听体系

java

复制

// 代码路径:frameworks/base/packages/SystemUI/src/com/android/systemui/statusbar/NotificationListener.javapublic class NotificationListener extends NotificationListenerWithPlugins {@Overridepublic void onNotificationPosted(StatusBarNotification sbn, RankingMap rankingMap) {mMainHandler.post(() -> {// 关键处理流程:// 1. RemoteInput预处理(进程间通信安全)// 2. 多处理器分发机制(NotificationHandler扩展)for (NotificationHandler handler : mNotificationHandlers) {handler.onNotificationPosted(sbn, rankingMap);}});}
}

4.2 事件处理时序分析

mermaid

复制

sequenceDiagramparticipant App as 应用进程participant NMS as NotificationManagerServiceparticipant SystemUI as SystemUI进程App->>NMS: notifyAsUser()NMS->>NMS: enqueueNotificationInternal()NMS->>NMS: EnqueueNotificationRunnableNMS->>SystemUI: Binder IPC通知SystemUI->>NotificationListener: onNotificationPosted()NotificationListener->>NotificationPresenter: 事件分发NotificationPresenter->>StatusBar: 更新UI

关键时序控制

  1. 跨进程通信(Binder性能优化)

  2. UI线程同步(Handler消息机制)

  3. 事件分发策略(责任链模式)

5. 高级调试与定制技巧

5.1 常见问题排查指南

问题现象排查方向调试命令
通知不显示渠道重要性设置adb shell dumpsys notification
通知图标异常资源适配检查uiautomator dump
通知延迟Handler消息队列分析adb shell dumpsys activity top
跨用户通知失败UserHandle有效性验证adb shell pm list users

5.2 性能优化策略

  1. 批量通知处理:采用NotificationManager.notify()的重载方法进行批量更新

  2. Binder调用优化:减少跨进程通信次数,合并通知更新操作

  3. 内存管理:及时回收LargeIcon等位图资源

  4. 异步加载机制:对于网络图片等耗时资源使用异步加载

6. 定制化开发实践

6.1 通知拦截扩展

java

复制

// 在NotificationListenerService扩展点实现自定义过滤
public class CustomNotificationListener extends NotificationListenerService {@Overridepublic void onNotificationPosted(StatusBarNotification sbn) {if (shouldBlock(sbn)) {cancelNotification(sbn.getKey());}}private boolean shouldBlock(StatusBarNotification sbn) {// 实现自定义过滤逻辑return sbn.getPackageName().contains("ad");}
}

6.2 动态渠道管理

java

复制

// 动态调整通知渠道重要性
NotificationChannel channel = mManager.getNotificationChannel(channelId);
if (channel.getImportance() < IMPORTANCE_HIGH) {channel.setImportance(IMPORTANCE_HIGH);mManager.updateNotificationChannel(channel);
}

7. 结语

深入理解Android通知机制需要掌握从Java API到Native服务的完整调用链路。本文通过剖析Framework层到SystemUI的完整流程,揭示了以下关键技术点:

  1. 跨进程通信机制:Binder在通知传递中的核心作用

  2. 异步处理模型:Handler在系统服务中的典型应用

  3. 资源管理策略:图标、音效等资源的优化处理

  4. 安全控制体系:用户隔离与权限验证机制

建议开发者在进行ROM定制时,重点关注NotificationRecord的状态管理和RankingHelper的排序算法,这两个模块是通知系统行为定制的关键切入点。同时注意Android 13新增的运行时通知权限(POST_NOTIFICATIONS)对系统行为的影响,做好兼容性适配。

转载请注明出处Android系统通知机制深度解析:Framework至SystemUI全链路剖析-CSDN博客,谢谢合作!

相关文章:

Android系统通知机制深度解析:Framework至SystemUI全链路剖析

1. 前言 在Android 13的ROM定制化开发中&#xff0c;系统通知机制作为用户交互的核心组件&#xff0c;其实现涉及Framework层到SystemUI的复杂协作。本文将深入剖析从Notification发送到呈现的全链路流程&#xff0c;重点解析关键类的作用机制及系统服务间的交互逻辑&#xff…...

重学Redis:Redis常用数据类型+存储结构(源码篇)

一、SDS 1&#xff0c;SDS源码解读 sds (Simple Dynamic String)&#xff0c;Simple的意思是简单&#xff0c;Dynamic即动态&#xff0c;意味着其具有动态增加空间的能力&#xff0c;扩容不需要使用者关心。String是字符串的意思。说白了就是用C语言自己封装了一个字符串类型&a…...

Elasticsearch的Java客户端库QueryBuilders查询方法大全

matchAllQuery 使用方法&#xff1a;创建一个查询&#xff0c;匹配所有文档。 示例&#xff1a;QueryBuilders.matchAllQuery() 注意事项&#xff1a;这种查询不加任何条件&#xff0c;会返回索引中的所有文档&#xff0c;可能会影响性能&#xff0c;特别是文档数量很多时。 ma…...

js原型和原型链

js原型&#xff1a; 1、原型诞生的目的是什么呢&#xff1f; js原型的产生是为了解决在js对象实例之间共享属性和方法&#xff0c;并把他们很好聚集在一起&#xff08;原型对象上&#xff09;。每个函数都会创建一个prototype属性&#xff0c;这个属性指向的就是原型对象。 …...

usb重定向qemu前端处理

1、qemu添加spicevmc前端时会创建vmc通道。 -chardev spicevmc,idusbredirchardev0,nameusbredir red::shared_ptr<RedCharDevice> spicevmc_device_connect(RedsState *reds, SpiceCharDeviceInstance *sin, uint8_t channel_type) {auto channel(red_vmc_channel_new(r…...

OpenHarmony - 小型系统内核(LiteOS-A)(五)

OpenHarmony - 小型系统内核&#xff08;LiteOS-A&#xff09;&#xff08;五&#xff09; 六、文件系统 虚拟文件系统 基本概念 VFS&#xff08;Virtual File System&#xff09;是文件系统的虚拟层&#xff0c;它不是一个实际的文件系统&#xff0c;而是一个异构文件系统之…...

PyTorch进阶学习笔记[长期更新]

第一章 PyTorch简介和安装 PyTorch是一个很强大的深度学习库&#xff0c;在学术中使用占比很大。 我这里是Mac系统的安装&#xff0c;相比起教程中的win/linux安装感觉还是简单不少&#xff08;之前就已经安好啦&#xff09;&#xff0c;有需要指导的小伙伴可以评论。 第二章…...

proteus8.17 环境配置

Proteus介绍 Proteus 8.17 是一款功能强大的电子设计自动化&#xff08;EDA&#xff09;软件&#xff0c;广泛应用于电子电路设计、仿真和分析。以下是其主要特点和新功能&#xff1a; ### 主要功能 - **电路仿真**&#xff1a;支持数字和模拟电路的仿真&#xff0c;包括静态…...

Microsoft SQL Server Management 一键删除数据库所有外键

DECLARE ESQL VARCHAR(1000); DECLARE FCursor CURSOR --定义游标 FOR (SELECT ALTER TABLE O.name DROP CONSTRAINT F.name; AS CommandSQL from SYS.FOREIGN_KEYS F JOIN SYS.ALL_OBJECTS O ON F.PARENT_OBJECT_ID O.OBJECT_ID WHERE O.TYPE U AND F.TYPE …...

【JAVAFX】自定义FXML 文件存放的位置以及使用

情况 1&#xff1a;FXML 文件与调用类在同一个包中&#xff08;推荐&#xff09; 假设类 MainApp 的包是 com.example&#xff0c;且 FXML 文件放在 resources/com/example 下&#xff1a; 项目根目录 ├── src │ └── sample │ └── Main.java ├── src/s…...

Oracle 如何停止正在运行的 Job

Oracle 如何停止正在运行的 Job 先了解是dbms_job 还是 dbms_scheduler&#xff0c;再确定操作命令。 一 使用 DBMS_JOB 包停止作业&#xff08;适用于旧版 Job&#xff09; 1.1 查看正在运行的 Job SELECT job, what, this_date, this_sec, failures, broken FROM user_j…...

高级语言调用C接口(四)结构体(2)-Python

这个专栏好久没有更新了&#xff0c;主要是坑开的有点大&#xff0c;也不知道怎么填&#xff0c;涉及到的开发语言比较多&#xff0c;写起来比较累&#xff0c;需要看的人其实并不多&#xff0c;只能说&#xff0c;慢慢填吧&#xff0c;中间肯定还会插很多别的东西&#xff0c;…...

Java对接Dify API接口完整指南

Java对接Dify API接口完整指南 一、Dify API简介 Dify是一款AI应用开发平台&#xff0c;提供多种自然语言处理能力。通过调用Dify开放API&#xff0c;开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中。 二、准备工作 获取API密钥 登录Dify平台控制台在「API密…...

极狐GitLab GEO 功能介绍

极狐GitLab 是 GitLab 在中国的发行版&#xff0c;关于中文参考文档和资料有&#xff1a; 极狐GitLab 中文文档极狐GitLab 中文论坛极狐GitLab 官网 Geo (PREMIUM SELF) Geo 是广泛分布的开发团队的解决方案&#xff0c;可作为灾难恢复策略的一部分提供热备份。Geo 不是 开箱…...

Nginx-前言

nginx是什么&#xff1f; 轻量级&#xff0c;开源免费的web服务器软件&#xff0c;服务器安装nginx&#xff0c;服务器则成为web服务器 nginx的稳定版版本号&#xff1a; 偶数版本 nginx的相关目录&#xff1a; /etc/nginx/nginx.conf nginx的主配置文件 /etc/nginx/ngi…...

LFI to RCE

LFI不止可以来读取文件&#xff0c;还能用来RCE 在多道CTF题目中都有LFItoRCE的非预期解&#xff0c;下面总结一下LFI的利用姿势 1. /proc/self/environ 利用 条件&#xff1a;目标能读取 /proc/self/environ&#xff0c;并且网页中存在LFI点 利用方式&#xff1a; 修改请…...

云原生(Cloud Native)的详解、开发流程及同类软件对比

以下是云原生&#xff08;Cloud Native&#xff09;的详解、开发流程及同类软件对比&#xff1a; 一、云原生核心概念 定义&#xff1a; 云原生&#xff08;Cloud Native&#xff09;是基于云环境设计和运行应用程序的方法论&#xff0c;强调利用云平台的弹性、分布式和自动化…...

全局唯一标识符(UID)生成策略

目录 一、UUID 二、雪花算法 三、时间戳 随机数 四、利用数据库的自增字段 五、 基于 Redis 的原子操作 总结 在信息系统中&#xff0c;生成唯一ID是非常常见的需求&#xff0c;尤其是在分布式系统或高并发场景下。以下是几种常见的生成唯一ID的算法或方式&#xff1a; …...

学习笔记:减速机工作原理

学习笔记&#xff1a;减速机工作原理 一、减速机图片二、减速比概念三、减速机的速比与扭矩之间的关系四、题外内容--电机扭矩 一、减速机图片 二、减速比概念 即减速装置的传动比&#xff0c;是传动比的一种&#xff0c;是指减速机构中&#xff0c;驱动轴与被驱动轴瞬时输入速…...

《UE5_C++多人TPS完整教程》学习笔记36 ——《P37 拾取组件(Pickup Widget)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P37 拾取组件&#xff08;Pickup Widget&#xff09;》 的学习笔记&#xff0c;该系列教学视频为计算机工程师、程序员、游戏开发者、作家&#xff08;Engineer, Programmer, Game Developer, Author&#xff09; Steph…...

《空间复杂度(C语言)》

文章目录 前言一、什么是空间复杂度&#xff1f;通俗理解&#xff1a; 二、空间复杂度的数学定义三、常见空间复杂度举例&#xff08;含C语言代码&#xff09;&#x1f539; O(1)&#xff1a;常数空间&#x1f539; O(n)&#xff1a;线性空间&#x1f539; O(n^2)&#xff1a;平…...

Kaggle-Store Sales-(回归+多表合并+xgboost模型)

Store Sales 题意&#xff1a; 给出很多商店&#xff0c;给出商店的类型&#xff0c;某时某刻卖了多少销售额。 给出了油价表&#xff0c;假期表&#xff0c;进货表。 让你求出测试集合中每个商店的销售额是多少。 数据处理: 1.由于是多表&#xff0c;所以要先把其他表与tr…...

在 Tailwind CSS 中优雅地隐藏滚动条

在开发中&#xff0c;我们经常需要隐藏滚动条但保持滚动功能&#xff0c;这在构建现代化的用户界面时很常见。 本文将介绍两种在 Tailwind CSS 项目中实现这一目标的方法&#xff0c;方便同学们记录和查阅。 方法一&#xff1a;使用 tailwind-scrollbar-hide 插件 这是一种更…...

智能合约安全审计平台——以太坊虚拟机安全沙箱

目录 以太坊虚拟机安全沙箱 —— 理论、设计与实战1. 引言2. 理论背景与安全原理2.1 以太坊虚拟机(EVM)概述2.2 安全沙箱的基本概念2.3 安全证明与形式化验证3. 系统架构与模块设计3.1 模块功能说明3.2 模块之间的数据流与安全性4. 安全性与密码学考量4.1 密码学保障在沙箱中…...

std::unordered_map(C++)

std::unordered_map 1. 概述2. 内部实现3. 性能特征4. 常用 API5. 使用示例6. 自定义哈希与相等比较7. 注意事项与优化8. 使用建议9. emplace和insert异同相同点不同点例子对比何时优先使用哪种&#xff1f; 1. 概述 定义&#xff1a;std::unordered_map<Key, T, Hash, KeyE…...

【MCP教程】Claude Desktop 如何连接部署在远程的remote mcp server服务器(remote host)

前言 最近MCP特别火热&#xff0c;笔者自己也根据官方文档尝试了下。 官方文档给的Demo是在本地部署一个weather.py&#xff0c;然后用本地的Claude Desktop去访问该mcp服务器&#xff0c;从而完成工具的调用&#xff1a; 但是&#xff0c;问题来了&#xff0c;Claude Deskto…...

Android Input——输入事件回调完成(十四)

前面几篇文章介绍了事件回调的相关流程,以及回调事件处理函数的相关内容,最后我们再来看一下事件处理完后,如何通知 InputDispatcher 去回调 Callback。 一、客户端回调 在 Android 的事件分发机制中,当客户端(即应用层)完成事件处理后,最终会调用 ViewRootImpl 的 fin…...

数据通信学习笔记之OSPF配置命令

华为 [huawei]ospf 10 router-id 1.1.1.1 //创建ospf进程&#xff0c;本地有效area 1 // 进入区域1network 192.168.1.0 0.0.0.255 // 宣告网段&#xff0c;使用反掩码stub // 配置为stub区域stub no-summary // 配置为Totally Stub 完全末节区域。在ABR上配置&#xff0…...

Python -yield 在python 中什么意思

在 Python 中&#xff0c;yield 是一个关键字&#xff0c;用于定义生成器函数&#xff08;generator function&#xff09;。它的作用是将一个普通函数转变为可迭代的生成器&#xff0c;具有惰性计算的特性。以下是关键要点&#xff1a; 核心概念 生成器函数&#xff1a; 当函数…...

多个路由器互通(静态路由)无单臂路由(简单版)

多个路由器互通&#xff08;静态路由&#xff09;无单臂路由&#xff08;简单版&#xff09; 开启端口并配ip地址 维护1 Router>en Router#conf t Router(config)#int g0/0 Router(config-if)#no shutdown Router(config-if)#ip address 192.168.10.254 255.255.255.0 Ro…...