efficiency-resources-apply-dev-guide.md 2.5 KB
Newer Older
1
# Efficiency Resource Request Development
2

3
## When to Use
4 5 6 7 8

To further balance power consumption overhead of the system, privileged system applications can be suspended in the background as other applications. To ensure normal provisioning of important functions, efficiency resource APIs are provided for these applications so that they can execute special tasks and use specific system resources in the background. For example, if they want to receive common events when suspended, they can use the APIs to request the common event resources.

To upgrade your application as a privileged application, you must evaluate your service requirements and submit a request to the application center. The application center will determine whether to accept the request based on the conditions.

9 10 11
## Constraints
Only system applications can request efficiency resources.

12
## Available APIs
13 14 15

**Table 1** Main APIs for efficiency resources

16 17 18 19
| API                                     | Description        |
| ---------------------------------------- | ---------- |
| applyEfficiencyResources(request: [EfficiencyResourcesRequest](../reference/apis/js-apis-resourceschedule-backgroundTaskManager.md#efficiencyresourcesrequest)): boolean | Requests efficiency resources.   |
| resetAllEfficiencyResources():void       | Releases efficiency resources.|
20 21


22
## How to Develop
23 24 25 26 27

1. When a privileged application in the background needs to use special resources, request the target resources from the system.

2. When the task is complete, release the resources in time. You can choose whether to release some or all resources.

28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
   ```js
   import backgroundTaskManager from '@ohos.backgroundTaskManager';
   
   // Request efficiency resources.
   let request = {
       resourceTypes: backgroundTaskManager.ResourceType.COMMON_EVENT |
           backgroundTaskManager.ResourceType.TIMER,
       isApply: true,
       timeOut: 0,
       reason: "apply",
       isPersist: true,
       isProcess: true,
   };
   let res = backgroundTaskManager.applyEfficiencyResources(request);
   console.info("the result of request is: " + res);
   
   // Release some efficiency resources.
   request = {
       resourceTypes: backgroundTaskManager.ResourceType.COMMON_EVENT,
       isApply: false,
       timeOut: 0,
       reason: "reset",
   };
   res = backgroundTaskManager.applyEfficiencyResources(request);
   console.info("the result of request is: " + res);
   
   // Release all efficiency resources.
   backgroundTaskManager.resetAllEfficiencyResources();
   ```