• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 短时任务(C/C++)
2
3## 场景介绍
4
5应用退至后台一小段时间后,应用进程会被挂起,无法执行对应的任务。如果应用在后台仍需要执行耗时不长的任务,如状态保存等,可以通过本文申请短时任务,扩展应用在后台的运行时间。
6
7## 接口说明
8
9常用接口如下表所示,具体API说明详见[API参考](../reference/apis-backgroundtasks-kit/capi-transient-task-api-h.md#函数)。
10
11
12| 接口名 | 描述 |
13| -------- | -------- |
14| int32_t OH_BackgroundTaskManager_RequestSuspendDelay(const char *reason, TransientTask_Callback callback, TransientTask_DelaySuspendInfo *info); | 申请短时任务。 |
15| int32_t OH_BackgroundTaskManager_GetRemainingDelayTime(int32_t requestId, int32_t *delayTime); | 获取对应短时任务的剩余时间。 |
16| int32_t OH_BackgroundTaskManager_CancelSuspendDelay(int32_t requestId); | 取消短时任务。 |
17| int32_t OH_BackgroundTaskManager_GetTransientTaskInfo(TransientTask_TransientTaskInfo  *transientTaskInfo); | 获取所有短时任务信息,如当日剩余总配额等。 |
18
19## 开发步骤
20
21### 在napi_init.cpp文件中封装接口并注册模块
22
231. 封装函数
24
25   ```C
26   #include "napi/native_api.h"
27   #include "transient_task/transient_task_api.h"
28
29   TransientTask_DelaySuspendInfo delaySuspendInfo;
30
31   static void callback(void)
32   {
33      // 短时任务即将结束,业务在这里取消短时任务
34      OH_BackgroundTaskManager_CancelSuspendDelay(delaySuspendInfo.requestId);
35   }
36
37   // 申请短时任务
38   static napi_value RequestSuspendDelay(napi_env env, napi_callback_info info)
39   {
40         napi_value result;
41         int32_t res = OH_BackgroundTaskManager_RequestSuspendDelay("test", callback, &delaySuspendInfo);
42         if (res == 0) {
43            napi_create_int32(env, delaySuspendInfo.requestId, &result);
44         } else {
45            napi_create_int32(env, -1, &result);
46         }
47         return result;
48   }
49
50   // 获取剩余时间
51   static napi_value GetRemainingDelayTime(napi_env env, napi_callback_info info)
52   {
53         napi_value result;
54         int32_t delayTime = 0;
55         int32_t res = OH_BackgroundTaskManager_GetRemainingDelayTime(delaySuspendInfo.requestId, &delayTime);
56         if (res == 0) {
57            napi_create_int32(env, delayTime, &result);
58         } else {
59            napi_create_int32(env, -1, &result);
60         }
61         return result;
62   }
63
64   // 取消短时任务
65   static napi_value CancelSuspendDelay(napi_env env, napi_callback_info info)
66   {
67         napi_value result;
68         int32_t res = OH_BackgroundTaskManager_CancelSuspendDelay(delaySuspendInfo.requestId);
69         napi_create_int32(env, res, &result);
70         return result;
71   }
72
73   // 获取所有短时任务信息
74   TransientTask_TransientTaskInfo transientTaskInfo;
75
76   static napi_value GetTransientTaskInfo(napi_env env, napi_callback_info info)
77   {
78      napi_value result;
79      napi_create_object(env, &result);
80      int32_t res = OH_BackgroundTaskManager_GetTransientTaskInfo(&transientTaskInfo);
81      napi_value napiRemainingQuota = nullptr;
82      // 获取成功,格式化数据并返回给接口
83      if (res == 0) {
84         napi_create_int32(env, transientTaskInfo.remainingQuota, &napiRemainingQuota);
85         napi_set_named_property(env, result, "remainingQuota", napiRemainingQuota); // 格式化当日总配额
86
87         napi_value info {nullptr};
88         napi_create_array(env, &info);
89         uint32_t count = 0;
90         // 格式化所有已申请的短时任务信息
91         for (int index = 0; index < 3; index++) {
92            if (transientTaskInfo.transientTasks[index].requestId == 0) {
93                continue;
94            }
95
96            napi_value napiWork = nullptr;
97            napi_create_object(env, &napiWork);
98
99            napi_value napiRequestId = nullptr;
100            napi_create_int32(env, transientTaskInfo.transientTasks[index].requestId, &napiRequestId);
101            napi_set_named_property(env, napiWork, "requestId", napiRequestId);
102
103            napi_value napiActualDelayTime = nullptr;
104            napi_create_int32(env, transientTaskInfo.transientTasks[index].actualDelayTime, &napiActualDelayTime);
105            napi_set_named_property(env, napiWork, "actualDelayTime", napiActualDelayTime);
106
107            napi_set_element(env, info, count, napiWork);
108            count++;
109         }
110         napi_set_named_property(env, result, "transientTasks", info);
111      } else {
112         napi_create_int32(env, 0, &napiRemainingQuota);
113         napi_set_named_property(env, result, "remainingQuota", napiRemainingQuota);
114         napi_value info {nullptr};
115         napi_create_array(env, &info);
116         napi_set_named_property(env, result, "transientTasks", info);
117      }
118      return result;
119   }
120   ```
121
1222. 注册函数
123
124   ```C
125   EXTERN_C_START
126   static napi_value Init(napi_env env, napi_value exports)
127   {
128       napi_property_descriptor desc[] = {
129           {"RequestSuspendDelay", nullptr, RequestSuspendDelay, nullptr, nullptr, nullptr, napi_default, nullptr},
130           {"GetRemainingDelayTime", nullptr, GetRemainingDelayTime, nullptr, nullptr, nullptr, napi_default, nullptr},
131           {"CancelSuspendDelay", nullptr, CancelSuspendDelay, nullptr, nullptr, nullptr, napi_default, nullptr},
132           {"GetTransientTaskInfo", nullptr, GetTransientTaskInfo, nullptr, nullptr, nullptr, napi_default, nullptr },
133       };
134       napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
135       return exports;
136   }
137   EXTERN_C_END
138   ```
139
1403. 注册模块
141
142   ```C
143   static napi_module demoModule = {
144       .nm_version = 1,
145       .nm_flags = 0,
146       .nm_filename = nullptr,
147       .nm_register_func = Init,
148       .nm_modname = "entry",
149       .nm_priv = ((void*)0),
150       .reserved = { 0 },
151   };
152
153   extern "C" __attribute__((constructor)) void RegisterEntryModule(void)
154   {
155       napi_module_register(&demoModule);
156   }
157   ```
158
159### 在index.d.ts文件中声明函数
160
161   ```ts
162   import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
163
164   export const RequestSuspendDelay: () => number;
165   export const GetRemainingDelayTime: () => number;
166   export const CancelSuspendDelay: () => number;
167   export const GetTransientTaskInfo: () => backgroundTaskManager.TransientTaskInfo;
168   ```
169
170### 在index.ets文件中调用函数
171
172   ```ts
173   import testTransientTask from 'libentry.so';
174
175   @Entry
176   @Component
177   struct Index {
178     @State message: string = '';
179
180     build() {
181       Row() {
182         Column() {
183           Text(this.message)
184             .fontSize(50)
185             .fontWeight(FontWeight.Bold)
186           Button('申请短时任务').onClick(event => {
187             this.RequestSuspendDelay();
188           })
189           Button('获取剩余时间').onClick(event =>{
190             this.GetRemainingDelayTime();
191           })
192           Button('取消短时任务').onClick(event =>{
193             this.CancelSuspendDelay();
194           })
195           Button('获取所有短时任务信息').onClick(event =>{
196             this.GetTransientTaskInfo();
197           })
198         }
199         .width('100%')
200        }
201       .height('100%')
202     }
203
204     RequestSuspendDelay() {
205       let requestId = testTransientTask.RequestSuspendDelay();
206       console.log("The return requestId is " + requestId);
207     }
208
209     GetRemainingDelayTime() {
210       let time = testTransientTask.GetRemainingDelayTime();
211       console.log("The time is " + time);
212     }
213
214     CancelSuspendDelay() {
215       let ret = testTransientTask.CancelSuspendDelay();
216       console.log("The ret is " + ret);
217     }
218
219     GetTransientTaskInfo() {
220       let ret = testTransientTask.GetTransientTaskInfo();
221       console.log("The ret is " + JSON.stringify(ret));
222     }
223   }
224
225   ```
226
227### 配置库依赖
228
229配置`CMakeLists.txt`,本模块需要用到的共享库是`libtransient_task.so`,在工程自动生成的`CMakeLists.txt`中的`target_link_libraries`中添加此共享库。
230
231   ```txt
232   target_link_libraries(entry PUBLIC libace_napi.z.so libtransient_task.so)
233   ```
234
235## 测试步骤
236
2371. 连接设备并运行程序。
238
2392. 点击 `申请短时任务` 按钮,控制台会打印日志,示例如下:
240
241   ```
242   The return requestId is 1
243   ```
244
2453. 点击 `获取剩余时间` 按钮,控制台会打印日志,示例如下:
246
247   ```
248   The return requestId is 18000
249   ```
2504. 点击 `取消短时任务` 按钮,控制台会打印日志,示例如下:
251
252   ```
253   The ret is 0
254   ```
2555. 点击 `获取所有短时任务信息` 按钮,控制台会打印日志,示例如下:
256
257   ```
258   The ret is {"remainingQuota":600000,"transientTasks":[]}
259   ```
260> **说明**
261>
262>申请短时任务的按钮,不可连续点击超过3次,否则会报错。使用过程中更多的约束与限制请参考[短时任务(ArkTS)](transient-task.md#约束与限制)。
263