1<!--RP1-->
2# 后台任务总体概述<!--RP1End-->
3
4
5## 功能介绍
6
7设备返回主界面、锁屏、应用切换等操作会使应用退至后台。应用退至后台后,如果继续活动,可能会造成设备耗电快、用户界面卡顿等现象。为了降低设备耗电速度、保障用户使用流畅度,系统会对退至后台的应用进行管控,包括进程挂起和进程终止。
8挂起后,应用进程无法使用软件资源(如公共事件、定时器等)和硬件资源(CPU、网络、GPS、蓝牙等)。<!--RP2--><!--RP2End-->
9
10- 应用退至后台一小段时间(由系统定义),应用进程会被挂起。
11
12- 应用退至后台,在后台被访问一小段时间(由系统定义)后,应用进程会被挂起。
13
14- 资源不足时,系统会终止部分应用进程(即回收该进程的所有资源)。
15
16同时,为了保障后台音乐播放、日历提醒等功能的正常使用,系统提供了规范内受约束的后台任务,扩展应用在后台运行时间。
17
18## 资源使用约束
19对于运行的进程,系统会给予一定的资源配额约束,包括进程在连续一段时间内内存的使用、<!--RP3-->CPU使用占比<!--RP3End-->,以及24小时磁盘写的IO量,均有对应的配额上限。超过配额上限时,如果进程处于前台,系统会有对应的warning日志,如果进程处于后台,系统会终止该进程。
20
21
22## 后台任务类型
23
24标准系统支持规范内受约束的后台任务,包括短时任务、长时任务、延迟任务、代理提醒和能效资源。
25
26开发者可以根据如下的功能介绍,选择合适的后台任务,以满足应用退至后台后继续运行的需求。
27
28- **短时任务**:适用于实时性要求高、耗时不长的任务,例如状态保存。
29
30- **长时任务**:适用于长时间运行在后台、用户可感知的任务,例如后台播放音乐、导航、设备连接等,使用长时任务避免应用进程被挂起。
31
32- **延迟任务**:对于实时性要求不高、可延迟执行的任务,系统提供了延迟任务,即满足条件的应用退至后台后被放入执行队列,系统会根据内存、功耗等统一调度。
33
34- **代理提醒**:代理提醒是指应用退后台或进程终止后,系统会代理应用做相应的提醒。适用于定时提醒类业务,当前支持的提醒类型包括倒计时、日历和闹钟三类。
35
36<!--Del-->
37同时,对于提供基础能力的系统应用,系统单独提供[能效资源申请](efficiency-resource-request.md)接口。应用调用能效资源接口后,系统对应用进行一定的管控豁免。<!--DelEnd-->
38
39  **图1** 后台任务类型选择  
40![bgtask_choice](figures/bgtask_choice.png)
41
42
43> **说明:**
44>
45> 1. 系统仅支持规范内受约束的后台任务。应用退至后台后,若未使用规范内的后台任务或选择的后台任务类型不正确,对应的应用进程会被挂起或终止。
46>
47> 2. 应用申请了规范内的后台任务,仅会提升应用进程被回收的优先级。当系统资源严重不足时,即使应用进程申请了规范内的后台任务,系统仍会终止部分进程,用以保障系统稳定性。