1# 内存管理purgeable内存开发指导
2
3## 场景介绍
4
5OpenHarmony提供Purgeable Memory内存管理机制,开发者可以使用相关接口创建PurgeableMemory对象,从而管理purgeable内存。
6
7
8开发者可以通过本指导了解在OpenHarmony应用中,如何使用Native层相关接口操作purgeable内存。功能包括purgeable内存的申请、释放等。
9
10
11针对Purgeable Memory内存管理机制,常见的开发场景如下:
12
13* 通过该机制提供的`NAPI`接口申请管理PurgeableMemory对象,并将数据内容写入该对象。
14* 使用完毕后释放。
15
16## 接口说明
17
18| 接口名 | 描述 |
19| -------- | -------- |
20| OH_PurgeableMemory \*OH_PurgeableMemory_Create(size_t size, OH_PurgeableMemory_ModifyFunc func, void \*funcPara) | 创建PurgeableMemory对象,每次调用都会产生一个新的PurgeableMemory对象。 |
21| bool OH_PurgeableMemory_Destroy(OH_PurgeableMemory \*purgObj) | 对PurgeableMemory对象进行析构操作。 |
22| bool OH_PurgeableMemory_BeginRead(OH_PurgeableMemory \*purgObj) | 对PurgeableMemory对象进行读访问。 |
23| void OH_PurgeableMemory_EndRead(OH_PurgeableMemory \*purgObj) | 读操作结束,将PurgeableMemory对象的引用计数减1,当引用计数为0的时候, 该PurgeableMemory对象可以被系统回收。 |
24|bool OH_PurgeableMemory_BeginWrite(OH_PurgeableMemory \*purgObj) | 对PurgeableMemory对象进行写访问。|
25|void OH_PurgeableMemory_EndWrite(OH_PurgeableMemory \*purgObj)|写操作结束,将PurgeableMemory对象的引用计数减1,当引用计数为0的时候,该PurgeableMemory对象可以被系统回收。|
26|void \*OH_PurgeableMemory_GetContent(OH_PurgeableMemory \*purgObj)|获取PurgeableMemory对象内存数据。|
27|size_t OH_PurgeableMemory_ContentSize(OH_PurgeableMemory \*purgObj)|获取PurgeableMemory对象内存数据大小。|
28|bool OH_PurgeableMemory_AppendModify(OH_PurgeableMemory \*purgObj, OH_PurgeableMemory_ModifyFunc func, void \*funcPara)|添加PurgeableMemory对象的修改方法。|
29
30
31## Purgeable Memory应用开发步骤
32
33以下步骤描述了在**OpenHarmony**中如何使用`Purgeable Memory`提供的`NAPI`接口,申请PurgeableMemory对象,并将内容写入PurgeableMemory对象后,对相应对象进行读写访问。
34
351. 声明PurgeableMemory对象创建规则。
36    ```c++
37    // 声明构建函数的参数
38    struct ParaData{
39        int start;
40        int end;
41    };
42
43    // 声明一个使用ModifyFunc
44    bool FactorialFunc(void* data, size_t size, void* param){
45        bool ret = true;
46        ParaData *pdata = (ParaData*) param;
47        int* oriData = (int*)data;
48        int i = pdata->start;
49        while (i < pdata->end) {
50            *oriData *= i;
51            i++;
52        }
53        return ret;
54    }
55
56    // 声明修改PurgeableMemory对象扩展函数的参数
57    struct AppendParaData{
58        int newPara;
59    };
60
61    // 声明修改PurgeableMemory对象的扩展函数
62    bool AddFunc(void* data, size_t size, void* param){
63        bool ret = true;
64        int *oriDatap = (int*) data;
65        AppendParaData* apData = (AppendParaData*)param;
66        *oriDatap += apData->newPara;
67        return ret;
68    }
69    ```
702. 创建PurgeableMemory对象。
71    ```c++
72    // 声明一个4MB的PurgeableMemory对象大小
73    #define DATASIZE (4 * 1024 * 1024)
74
75    // 声明创建函数的参数
76    struct ParaData pdata = {1,2};
77
78    // 创建一个PurgeableMemory对象
79    OH_PurgeableMemory* pPurgmem = OH_PurgeableMemory_Create(DATASIZE, FactorialFunc, &pdata);
80    ```
81
823. 读访问PurgeableMemory对象。
83    ```c++
84    //业务定义对象类型
85    class ReqObj;
86
87    // 读取对象
88    if(OH_PurgeableMemory_BeginRead(pPurgmem)) {
89        // 获取PurgeableMemory对象大小
90        size_t size = OH_PurgeableMemory_ContentSize(pPurgmem);
91
92        // 获取PurgeableMemory对象内容
93        ReqObj* pReqObj = (ReqObj*) OH_PurgeableMemory_GetContent(pPurgmem);
94
95        // 读取PurgeableMemory对象结束
96        OH_PurgeableMemory_EndRead(pPurgmem);
97    }
98    ```
99
1004. 写访问PurgeableMemory对象。
101    ```c++
102     //业务定义对象类型
103    class ReqObj;
104
105    // 修改PurgeableMemory对象
106    if(OH_PurgeableMemory_BeginWrite(pPurgmem)) {
107        // 获取PurgeableMemory对象数据
108        ReqObj* pReqObj = (ReqObj*) OH_PurgeableMemory_GetContent(pPurgmem);
109
110        // 声明扩展创建函数的参数
111        struct AppendParaData apdata = {1};
112
113        // 更新PurgeableMemory对象重建规则
114        OH_PurgeableMemory_AppendModify(pPurgmem, AddFunc, &apdata);
115
116        // 修改PurgeableMemory对象结束
117        OH_PurgeableMemory_EndWrite(pPurgmem);
118    }
119    ```
120
1215. 销毁PurgeableMemory对象。
122    ```c++
123    // 销毁对象
124    OH_PurgeableMemory_Destroy(pPurgmem);
125    // 置空指针防止UAF
126    pPurgmem = nullptr;
127    ```