预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共21页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

(19)中华人民共和国国家知识产权局(12)发明专利申请(10)申请公布号CN113867925A(43)申请公布日2021.12.31(21)申请号202010612893.0(22)申请日2020.06.30(71)申请人龙芯中科技术股份有限公司地址100095北京市海淀区中关村环保科技示范园龙芯产业园2号楼(72)发明人张洪凯袁俊卿(74)专利代理机构北京同立钧成知识产权代理有限公司11205代理人罗英刘芳(51)Int.Cl.G06F9/50(2006.01)权利要求书2页说明书12页附图6页(54)发明名称内存管理方法、装置、设备和存储介质(57)摘要本申请提供一种内存管理方法、装置、设备和存储介质,该方法包括:获取内存管理指令;根据所述内存管理指令,获取内存的多个空闲内存块,所述多个空闲内存块为不连续的内存块;根据所述多个空闲内存块,得到目标空闲内存块,所述目标空闲内存块的内存空间大于所述多个空闲内存块中任意一个空闲内存块的内存空间。依据内存管理指令,获取多个空闲内存块,并根据多个空闲内存块整理得到内存空间更大的目标空闲内存块,达到整理系统内存碎片的效果,为系统运行提供更大的连续内存空间,从而提高系统内存利用率。CN113867925ACN113867925A权利要求书1/2页1.一种内存管理方法,其特征在于,包括:获取内存管理指令;根据所述内存管理指令,获取内存的多个空闲内存块,所述多个空闲内存块为不连续的内存块;根据所述多个空闲内存块,得到目标空闲内存块,所述目标空闲内存块的内存空间大于所述多个空闲内存块中任意一个空闲内存块的内存空间。2.根据权利要求1所述的方法,其特征在于,所述内存管理指令中包括:第一信息,所述第一信息用于指示当前占用的内存块;所述根据所述内存管理指令,获取内存的多个空闲内存块,包括:根据所述当前占用的内存块,获取所述多个空闲内存块。3.根据权利要求2所述的方法,其特征在于,所述根据所述当前占用的内存块,获取所述多个空闲内存块,包括:根据所述当前占用的内存块,判断所述当前占用的内存块的相邻内存块是否为空闲;若是,则确定所述相邻内存块为所述空闲内存块。4.根据权利要求3所述的方法,其特征在于,还包括:若所述当前占用的内存块的相邻内存块不为空闲,则将所述相邻内存块作为当前占用的内存块,继续判断与所述相邻内存块相邻的内存块是否为空闲;若是,则确定与所述相邻内存块相邻的内存块为所述空闲内存块。5.根据权利要求3或4所述的方法,其特征在于,内存块包括头部;所述内存块的头部中包括第二信息和第三信息,所述第二信息用于指示所述内存块的上一个相邻内存块是否空闲,所述第三信息用于指示所述内存块的内存空间大小;若当前占用的内存块为第i个内存块,则所述根据所述当前占用的内存块,判断所述当前占用的内存块的相邻内存块是否为空闲,包括:从所述第i个内存块的头部中获取第二信息,并根据所述第二信息,判断第i-1个内存块是否为空闲,所述第i-1个内存块为所述第i个内存块的上一个相邻内存块;根据所述第三信息,确定第i+2个内存块;从所述第i+2个内存块的头部中获取第二信息,并根据所述第二信息,判断第i+1个内存块是否为空闲,所述第i+1个内存块为所述第i个内存块的下一个相邻内存块,所述第i+2个内存块为所述第i+1个内存块的下一个相邻内存块。6.根据权利要求5所述的方法,其特征在于,所述根据所述第三信息,确定第i+2个内存块,包括:根据所述第一信息、所述第i个内存块的头部中的第三信息,确定第i+1个内存块的起始地址;根据所述第i+1个内存块的起始地址、所述第i+1个内存块的头部中的第三信息,确定第i+2个内存块的起始地址。7.根据权利要求1-4任一项所述的方法,其特征在于,所述多个空闲内存块包括第一空闲内存块和第二空闲内存块,所述第一空闲内存块与所述第二空闲内存块之间存在N个当前占用的内存块且不存在空闲内存块,所述N为大于0的整数;所述根据所述多个空闲内存块,得到目标空闲内存块,包括:2CN113867925A权利要求书2/2页将所述第一空闲内存块的内存空间以及所述N个当前占用的内存块的内存空间,确定为目标内存空间;将所述目标内存空间划分为N个第一内存块和一个第二内存块,其中,N个第一内存块分别作为所述N个当前占用的内存块,所述第二内存块作为空闲内存块且与所述第二空闲内存块相邻;将所述第二内存块和所述第二空闲内存块合并为所述目标空闲内存块。8.根据权利要求7所述的方法,其特征在于,所述将所述目标内存空间划分为N个第一内存块和一个第二内存块,包括:判断所述N个当前占用的内存块的内存空间大小是否小于所述第一空闲内存块的内存空间大小;若是,则将所述N个当前占用的内存块中的数据对应移动到所述第一空闲内存块的尾部;以及将所述第一空闲块中包