• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Transient Task Development
2
3## When to Use
4
5By default, an application can run for a period of 6 to 12 seconds after it switches to the background. When this period expires, the application is suspended. If an application requires more time to execute an important task, it can call the **requestSuspendDelay** API to request a transient task to delay the suspension.
6
7You are advised not to call the **requestSuspendDelay()** method to apply for delayed suspension after the application is running in the background. Instead, you need to call this interface to declare the execution time of the extended application to the system before performing any time-consuming operation. It is recommended that an application calls **requestSuspendDelay()** when it is running in the foreground, so as not to affect the transient task quota of the application.
8
9An application can obtain the remaining duration before being suspended by calling [getRemainingDelayTime()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagergetremainingdelaytimecallback). Each application has a daily time quota for transient tasks. Therefore, after the time-consuming task finishes execution, the application should call [cancelSuspendDelay()](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#backgroundtaskmanagercancelsuspenddelay) to cancel the transient task in a timely manner.
10
11Typical time-consuming tasks include saving status data to the local database, opening and processing a large file, and synchronizing data to the cloud server.
12
13
14## Available APIs
15
16
17**Table 1** Main APIs for transient tasks
18
19| API                                     | Description                                      |
20| ---------------------------------------- | ---------------------------------------- |
21| requestSuspendDelay(reason: string, callback: Callback&lt;void&gt;): [DelaySuspendInfo](../reference/apis/js-apis-backgroundTaskManager.md#delaysuspendinfo)| Requests delayed suspension after the application switches to the background.<br>The default duration of delayed suspension is 3 minutes when the battery level is normal and 1 minute when the battery level is low.|
22| getRemainingDelayTime(requestId: number): Promise&lt;number&gt; | Obtains the remaining duration before the application is suspended.<br>This API uses a promise to return the result.  |
23| cancelSuspendDelay(requestId: number): void | Cancels the suspension delay.                                 |
24
25
26## How to Develop
27
28When an application needs to execute a time-consuming task in the background, call the API to request a transient task. After the time-consuming task finishes execution, call the API to cancel the transient task.
29
30```js
31import backgroundTaskManager from '@ohos.resourceschedule.backgroundTaskManager';
32
33let id; // ID of the suspension delay request.
34let delayTime; // Remaining duration for the suspension delay request.
35
36// Request a suspension delay.
37function requestSuspendDelay() {
38  let myReason = 'test requestSuspendDelay'; // Reason for the suspension delay request.
39
40  try {
41    let delayInfo = backgroundTaskManager.requestSuspendDelay(myReason, () => {
42      // The callback is invoked to notify the application that the suspension delay request is about to time out. The application needs to perform some cleanup and annotation operations and cancels the transient task.
43      console.info("[backgroundTaskManager] Request suspension delay will time out.");
44      backgroundTaskManager.cancelSuspendDelay(id);
45    })
46    id = delayInfo.requestId;
47    delayTime = delayInfo.actualDelayTime;
48    console.info("[backgroundTaskManager] The requestId is: " + id);
49    console.info("[backgroundTaskManager]The actualDelayTime is: " + delayTime);
50  } catch (error) {
51    console.error(`[backgroundTaskManager] requestSuspendDelay failed. code is ${error.code} message is ${error.message}`);
52  }
53}
54
55// Obtain the remaining duration before the application is suspended.
56async function getRemainingDelayTime() {
57  try {
58    await backgroundTaskManager.getRemainingDelayTime(id).then(res => {
59      console.log('[backgroundTaskManager] promise => Operation getRemainingDelayTime succeeded. Data: ' + JSON.stringify(res));
60    }).catch(error => {
61      console.error(`[backgroundTaskManager] promise => Operation getRemainingDelayTime failed. code is ${error.code} message is ${error.message}`);
62    })
63  } catch (error) {
64    console.error(`[backgroundTaskManager] promise => Operation getRemainingDelayTime failed. code is ${error.code} message is ${error.message}`);
65  }
66}
67
68// Cancel the suspension delay.
69function cancelSuspendDelay() {
70  backgroundTaskManager.cancelSuspendDelay(id);
71}
72
73async function performingLongRunningTask() {
74  // Before executing a time-consuming task, call the API to request a transient task to delay the suspension.
75  requestSuspendDelay();
76
77  // If required, obtain the available time quota through the getRemainingDelayTime() API.
78  await getRemainingDelayTime();
79
80  if (delayTime < 0) {// If the time is less than a certain value, cancel the time-consuming task.
81    // Handle the scenario where the time quota is insufficient.
82    cancelSuspendDelay();
83    return;
84  }
85
86  // Execute the time-consuming task.
87
88  // After the time-consuming task is executed, call the API to cancel the transient task.
89  cancelSuspendDelay();
90}
91```
92