鸿蒙开发入坑篇(十二):通知与后台任务 (Notifications)

可以体验下鸿蒙Ai:CodeArts Doer代码智能体

🔗 项目地址https://github.com/briefness/HarmonyDemo
更新说明 :本文将解析 IPC 通信系统代理服务,阐述通知与后台任务的机制。

一、理论基础:IPC 与 代理服务

1.1 跨进程通信 (IPC)

当调用 notificationManager.publish() 时,并非直接在 App 进程中绘制弹窗。
IPC/Binder
校验权限
通知渲染
绘制
App 进程
通知管理服务 (系统进程)
SystemUI 进程
通知栏/横幅

底层执行了跨进程通信 (IPC):

  1. App 进程: 序列化通知数据 (NotificationRequest),通过 Binder 驱动发送给系统服务。
  2. NotificationManagerService (NMS): 系统进程收到请求,校验权限。
  3. SystemUI: NMS 通知 SystemUI 进程渲染通知栏。

1.2 代理服务 (Proxy Service)

对于 代理提醒 (ReminderAgent),原理更进一步。

  • 应用将任务委托给系统。
  • ReminderService 是常驻内存的系统服务。即使应用进程被回收,系统服务仍会准时触发提醒。
  • 系统服务会负责唤醒设备、播放铃声,并拉起应用(如果配置了 WantAgent)。

二、通知 (NotificationKit)

2.1 核心要素

  1. Content: 通知的 UI 载体。
  2. Slot (通道) : 决定通知的干扰程度。
    • SOCIAL: 社交消息(有声、震动)。
    • SERVICE: 后台服务(静音)。
    • OTHER: 其他推广(静音、折叠)。

2.2 WantAgent (点击意图)

WantAgent 是一个被系统持有的"延迟执行意图"。

它本质上是一个序列化的 Action,可以在未来某个时刻(如用户点击通知时)由 AMS (AbilityManagerService) 触发。
用户 NotificationService (NMS) AbilityManagerService (AMS) App 用户 NotificationService (NMS) AbilityManagerService (AMS) App 创建 WantAgent (意图) 返回 Token 发布通知 (带 Token) 点击通知 触发 Token 启动 Ability (唤醒应用)

三、后台任务 (Background Tasks)

系统默认采用 冻结策略:App 切后台几秒后,JS 线程挂起,定时器停止。

3.1 短时任务 (Transient Task)

向系统申请临时后台运行时间。

typescript 复制代码
let delayId = backgroundTaskManager.requestSuspendDelay('reason', () => {
  // 超时回调:任务未完成,保存进度并清理
});

3.2 长时任务 (Continuous Task)

必须绑定一个 NOTIFICATION_ID

这也体现了前台服务 (Foreground Service) 的设计逻辑:用户必须知情。后台运行必须在通知栏体现。

四、总结

传统的保活机制在 HarmonyOS 上不再适用。

  • IPC 机制 决定了通知由系统接管。
  • 代理机制 决定了定时任务不需要应用存活。

建议使用 ReminderAgentWorkScheduler 实现相关功能。

下一篇,将进入混合开发的领域:Web 组件与 JSBridge

相关推荐
SummerKaze2 天前
为鸿蒙开发者写一个 nvm:hmvm 的设计与实现
harmonyos
在人间耕耘3 天前
HarmonyOS Vision Kit 视觉AI实战:把官方 Demo 改造成一套能长期复用的组件库
人工智能·深度学习·harmonyos
王码码20353 天前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
HarmonyOS_SDK3 天前
【FAQ】HarmonyOS SDK 闭源开放能力 — Ads Kit
harmonyos
Swift社区4 天前
如何利用 ArkUI 框架优化鸿蒙应用的渲染性能
华为·harmonyos
特立独行的猫a4 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
盐焗西兰花4 天前
鸿蒙学习实战之路-STG系列(5/11)-守护策略管理-添加与修改策略
服务器·学习·harmonyos
盐焗西兰花4 天前
鸿蒙学习实战之路-STG系列(4/11)-应用选择页功能详解
服务器·学习·harmonyos
lbb 小魔仙4 天前
鸿蒙跨平台项目实战篇03:React Native Bundle增量更新详解
react native·react.js·harmonyos
特立独行的猫a4 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS滚动卡片组件,scroll-view无法滚动踩坑全记录
华为·uni-app·harmonyos·uniapp-x