[发明专利]一种内存分配控制方法、装置、设备及存储介质在审
申请号: | 202110069958.6 | 申请日: | 2021-01-19 |
公开(公告)号: | CN112799832A | 公开(公告)日: | 2021-05-14 |
发明(设计)人: | 赵利平;方垒;兰文华;张玉波;严寒青 | 申请(专利权)人: | 杭州和利时自动化有限公司 |
主分类号: | G06F9/50 | 分类号: | G06F9/50 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 刘翠香 |
地址: | 310018 浙江省杭州市经*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 内存 分配 控制 方法 装置 设备 存储 介质 | ||
1.一种内存分配控制方法,其特征在于,包括:
接收申请方发送的内存申请,所述内存申请中携带申请内存大小的信息;
遍历空闲内存块列表,查找总内存大小与所述申请内存大小相同的空闲内存块;
在查找到的空闲内存块中分配内存给所述申请方。
2.根据权利要求1所述的方法,其特征在于,在所述遍历空闲内存块列表之后,还包括:
如果未查找到总内存大小与所述申请内存大小相同的空闲内存块,则根据所述申请内存大小,确定待分配集合,所述待分配集合中的每个空闲内存块的总内存大小与所述申请内存大小的比值大于设定比例阈值;
在所述待分配集合中选择一个空闲内存块,分配内存给所述申请方。
3.根据权利要求2所述的方法,其特征在于,所述在所述待分配集合中选择一个空闲内存块,分配内存给所述申请方,包括:
在所述待分配集合中选择总内存大小最大的空闲内存块,分配内存给所述申请方。
4.根据权利要求1所述的方法,其特征在于,还包括:
获得回收内存块;
根据所述回收内存块的地址,确定所述空闲内存块列表中是否存在地址连续的内存块;
如果存在,则将所述地址连续的内存块进行合并处理。
5.根据权利要求4所述的方法,其特征在于,所述空闲内存块列表中的空闲内存块按照地址前后顺序排列。
6.根据权利要求1至5之中任一项所述的方法,其特征在于,所述申请方为结构体对象,所述内存申请中携带所述结构体对象包含的每个字段的申请内存大小的信息;
所述查找总内存大小与所述申请内存大小相同的空闲内存块,包括:
针对所述结构体对象包含的每个字段,查找总内存大小与当前字段的申请内存大小相同的空闲内存块;
相应的,所述将查找到的空闲内存块分配给所述申请方,包括:
针对所述结构体对象包含的每个字段,将查找到的总内存大小与当前字段的申请内存大小相同的空闲内存块的内存分配给当前字段。
7.一种内存分配控制装置,其特征在于,包括:
内存申请接收模块,用于接收申请方发送的内存申请,所述内存申请中携带申请内存大小的信息;
空闲内存块查找模块,用于遍历空闲内存块列表,查找总内存大小与所述申请内存大小相同的空闲内存块;
内存分配模块,用于在查找到的空闲内存块中分配内存给所述申请方。
8.根据权利要求7所述的装置,其特征在于,所述内存分配模块,还用于:
在所述遍历空闲内存块列表之后,如果未查找到总内存大小与所述申请内存大小相同的空闲内存块,则根据所述申请内存大小,确定待分配集合,所述待分配集合中的每个空闲内存块的总内存大小与所述申请内存大小的比值大于设定比例阈值;
在所述待分配集合中选择一个空闲内存块,分配内存给所述申请方。
9.一种内存分配控制设备,其特征在于,包括:
存储器,用于存储计算机程序;
处理器,用于执行所述计算机程序时实现如权利要求1至6任一项所述内存分配控制方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至6任一项所述内存分配控制方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州和利时自动化有限公司,未经杭州和利时自动化有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110069958.6/1.html,转载请声明来源钻瓜专利网。