共计 2170 个字符,预计需要花费 6 分钟才能阅读完成。
摘要:内存调测办法旨在辅助定位动态内存相干问题,提供了根底的动态内存池信息统计伎俩,向用户出现内存池水线、碎片率等信息。
本文分享自华为云社区《鸿蒙轻内核 - 内存调测 - 内存信息统计》,作者:zhushy。
内存调测办法旨在辅助定位动态内存相干问题,提供了根底的动态内存池信息统计伎俩,向用户出现内存池水线、碎片率等信息;提供了内存透露检测伎俩,不便用户精确定位存在内存透露的代码行,也能够辅助剖析零碎各个模块内存的应用状况;提供了踩内存检测伎俩,能够辅助定位越界踩内存的场景。
本文剖析下内存信息统计。
1、根底概念
内存信息包含内存池大小、内存使用量、残余内存大小、最大闲暇内存、内存水线、内存节点数统计、碎片率等。
- 内存水线:即内存池的最大使用量,每次申请和开释时,都会更新水线值,理论业务可依据该值,优化内存池大小;
- 碎片率:掂量内存池的碎片化水平,碎片率高体现为内存池残余内存很多,然而最大闲暇内存块很小,能够用公式(fragment=100- 最大闲暇内存块大小 / 残余内存大小)来度量;
- 其余参数:通过内存治理模块的调用接口,扫描内存池的节点信息,统计出相干信息。
2、性能配置
LOSCFG_MEM_WATERLINE:开关宏,默认关上;若敞开这个性能,在 target_config.h 中将这个宏定义为 0。如需获取内存水线,须要关上该配置。
3、开发领导
要害构造体介绍:
typedef struct {
UINT32 totalUsedSize; // 内存池的内存使用量
UINT32 totalFreeSize; // 内存池的残余内存大小
UINT32 maxFreeNodeSize; // 内存池的最大闲暇内存块大小
UINT32 usedNodeNum; // 内存池的非闲暇内存块个数
UINT32 freeNodeNum; // 内存池的闲暇内存块个数
#if (LOSCFG_MEM_WATERLINE == 1) // 默认关上,如需敞开,在 target_config.h 中将该宏设置为 0
UINT32 usageWaterLine; // 内存池的水线值
#endif
} LOS_MEM_POOL_STATUS;
- 内存水线获取
调用 LOS_MemInfoGet 接口,第 1 个参数是内存池首地址,第 2 个参数是 LOS_MEM_POOL_STATUS 类型的句柄,其中字段 usageWaterLine 即水线值。 - 内存碎片率计算
同样调用 LOS_MemInfoGet 接口,能够获取内存池的残余内存大小和最大闲暇内存块大小,而后依据公式(fragment=100- 最大闲暇内存块大小 / 残余内存大小)得出此时的动态内存池碎片率。
4、编程实例
本实例实现如下性能:
1. 创立一个监控线程,用于获取内存池的信息;
2. 调用 LOS_MemInfoGet 接口,获取内存池的根底信息;
3. 利用公式算出使用率及碎片率。
代码实现如下:
#include <stdio.h>
#include <string.h>
#include "los_task.h"
#include "los_memory.h"
#include "los_config.h"
void MemInfoTaskFunc(void)
{LOS_MEM_POOL_STATUS poolStatus = {0};
LOS_MemInfoGet(m_aucSysMem0, &poolStatus);
/* 算出内存池以后的碎片率百分比 */
unsigned char fragment = 100 - poolStatus.maxFreeNodeSize * 100 / poolStatus.totalFreeSize;
/* 算出内存池以后的使用率百分比 */
unsigned char usage = LOS_MemTotalUsedGet(m_aucSysMem0) * 100 / LOS_MemPoolSizeGet(m_aucSysMem0);
printf("usage = %d, fragment = %d, maxFreeSize = %d, totalFreeSize = %d, waterLine = %d\n", usage, fragment, poolStatus.maxFreeNodeSize,
poolStatus.totalFreeSize, poolStatus.usageWaterLine);
}
int MemTest(void)
{
unsigned int ret;
unsigned int taskID;
TSK_INIT_PARAM_S taskStatus = {0};
taskStatus.pfnTaskEntry = (TSK_ENTRY_FUNC)MemInfoTaskFunc;
taskStatus.uwStackSize = 0x1000;
taskStatus.pcName = "memInfo";
taskStatus.usTaskPrio = 10;
ret = LOS_TaskCreate(&taskID, &taskStatus);
if (ret != LOS_OK) {printf("task create failed\n");
return -1;
}
return 0;
}
编译运行输入的后果如下:
usage = 22, fragment = 3, maxFreeSize = 49056, totalFreeSize = 50132, waterLine = 1414
点击关注,第一工夫理解华为云陈腐技术~
正文完