内存的申请使用方法及装置

阅读: 评论:0

著录项
  • CN201810750692.X
  • 20180710
  • CN109144902A
  • 20190104
  • 北京佳讯飞鸿电气股份有限公司
  • 任广磊
  • G06F12/14
  • G06F12/14 G06F9/50

  • 北京市海淀区锦带路88号院1号楼
  • 北京(11)
  • 北京超凡志成知识产权代理事务所(普通合伙)
  • 王术兰
摘要
本发明提供了一种内存的申请使用方法及装置,利用任务线程与资源池的交互,实现线程对内存的调用,内存释放后能够立即回收并再次利用,提高资源使用效率,并且消除了引用计数循环引用导致的内存泄露问题。通过ID访问内存,消除了野指针使用可能。方便统计内存使用率,可为优化应用程序提供手段。
权利要求

1.一种内存的申请使用方法,其特征在于,应用于任务线程,所述方法包括:

向资源池发送资源申请请求,以触发资源池分配内存;

接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

若有效,则接收所述资源池发送的资源有效信息,并使用内存。

2.根据权利要求1所述的方法,其特征在于,若有效,则接收所述资源池发送的资源有效信息,并使用内存之后,所述方法还包括:

向所述资源池发送释放资源请求,以触发所述资源池释放资源。

3.根据权利要求1所述的方法,其特征在于,所述方法还包括:

若所述内存无效,则接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

4.一种内存的申请使用方法,其特征在于,应用于资源池,所述方法包括:

接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

5.根据权利要求4所述的方法,其特征在于,若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存之后,所述方法还包括:

接收所述任务线程发送的资源释放请求,释放所述内存,并向所述任务线程发送释放成功信息。

6.一种内存的申请使用装置,其特征在于,应用于任务线程,所述装置包括:

申请模块,用于向资源池发送资源申请请求,以触发资源池分配内存;

接收模块,用于接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

检测模块,用于向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

使用模块,用于若有效,则接收所述资源池发送的资源有效信息,并使用内存。

7.根据权利要求6所述的装置,其特征在于,所述装置还包括:

释放模块,用于向所述资源池发送释放资源请求,以触发所述资源池释放资源。

8.根据权利要求6所述的装置,其特征在于,所述装置还包括:

再次请求模块,用于若所述内存无效,则接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

9.一种内存的申请使用装置,其特征在于,应用于资源池,所述装置包括:

申请请求接收模块,用于接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

使用请求接收模块,用于接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

有效信息发送模块,用于若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

10.一种计算机存储介质,其特征在于,用于储存为权利要求6至9任意一项所述的装置所用的计算机软件指令。

说明书
技术领域

本发明涉及资源管理技术领域,具体而言,涉及一种内存的申请使用方法及装置。

目前在多线程编程,对资源的使用一般采用引用计数、垃圾回收的方式使用资源。

比如在C++中引入了智能指针,程序员不用再纠结于建立出来的内存在哪释放比较合适这种问题。比如当一个资源被多个线程共享时,程序员需要在所有模块的生命周期都结束时,由最后一个不使用该指针的线程触发指针的释放行为。

然而凡事都不会尽善尽美,智能指针还是存在一定的缺陷:

(1)当循环引用发生时,基于引用计数的智能指针时,会带来的内存泄漏。

(2)资源释放需要等到引用计数为0时才能释放,资源利用率低。

(3)增加程序复杂性,当发生内存泄露问题时定位过程复杂。

针对上述现有技术中存在的问题,本发明提供了一种内存的申请使用方法。

第一方面,本发明实施例提供了一种内存的申请使用方法,应用于任务线程,所述方法包括:

向资源池发送资源申请请求,以触发资源池分配内存;

接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

若有效,则接收所述资源池发送的资源有效信息,并使用内存。

进一步的,若有效,则接收所述资源池发送的资源有效信息,并使用内存之后,所述方法还包括:

向所述资源池发送释放资源请求,以触发所述资源池释放资源。

进一步的,若所述内存无效,则接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

第二方面,本发明实施例提供了一种内存的申请使用方法,应用于资源池,所述方法包括:

接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

进一步的,若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存之后,所述方法还包括:

接收所述任务线程发送的资源释放请求,释放所述内存,并向所述任务线程发送释放成功信息。

第三方面,本发明实施例提供了一种内存的申请使用装置,应用于任务线程,所述装置包括:

申请模块,用于向资源池发送资源申请请求,以触发资源池分配内存;

接收模块,用于接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

检测模块,用于向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

使用模块,用于若有效,则接收所述资源池发送的资源有效信息,并使用内存。

进一步的,所述装置还包括:

释放模块,用于向所述资源池发送释放资源请求,以触发所述资源池释放资源。

进一步的,所述装置还包括:

再次请求模块,用于若所述内存无效,则接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

第四方面,本发明实施例提供了一种内存的申请使用装置,应用于资源池,所述装置包括:

申请请求接收模块,用于接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

使用请求接收模块,用于接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

有效信息发送模块,用于若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

第五方面,本发明实施例提供了一种计算机存储介质,用于储存为第三方面和第四方面所述的装置所用的计算机软件指令。

本发明实施例带来了以下有益效果:

本发明实施例提供了一种内存的申请使用方法及装置,利用任务线程与资源池的交互,实现线程对内存的调用,内存释放后能够立即回收并再次利用,提高资源使用效率,并且消除了引用计数循环引用导致的内存泄露问题。通过ID访问内存,消除了野指针使用可能。方便统计内存使用率,可为优化应用程序提供手段。

本发明的其他特征和优点将在随后的说明书中阐述,并且,部分地从说明书中变得显而易见,或者通过实施本发明而了解。本发明的目的地和其他优点在说明书、权利要求书以及附图中所特别指出的结构来实现和获得。

为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。

为了更清楚地说明本发明具体实施方式或现有技术中的技术方案,下面将对具体实施方式或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。

图1为本发明第一实施例所提供的一种内存的申请使用方法的流程图;

图2为本发明第二实施例所提供的一种内存的申请使用方法的流程图;

图3为本发明第三实施例所提供的一种内存的申请使用装置的结构框图;

图4为本发明第四实施例所提供的一种内存的申请使用装置的结构框图。

为使本发明实施例的目的地、技术方案和优点更加清楚,下面将结合附图对本发明的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。

目前,任务线程在处理任务的过程中需要从资源池中申请使用内存,本发明主要介绍任务线程与资源池交互使用内存的方法。

实施例一

参见图1所示的一种内存的申请使用方法的流程图,该方法应用于任务线程,任务线程包括任务分配线程和任务处理线程,具体包括如下步骤:

S101.向资源池发送资源申请请求,以触发资源池分配内存;

具体来说,任务分配线程收到用户请求,向资源池申请内存。

S102.接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

其中,内存标识可以为一个64位整形ID,该ID只在此资源生命周期内有效。ID由64位递增整形保证该ID在软件运行周期内不重复。

例如,资源池向任务分配线程返回ID为100地址为0x12340000的内存。任务分配线程向任务处理线程发布位于内存ID100的任务。

S103.向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

具体来说,任务处理线程使用资源时,需要通过ID100从资源池中获取内存地址。

若有效,则执行步骤S104。

S104.接收所述资源池发送的资源有效信息,并使用内存。

例如,资源池向任务处理线程返回ID100的内存地址0x12340000。任务处理线程对任务进行处理。

使用完成后,任务处理线程向所述资源池发送释放资源请求,以触发所述资源池释放资源。

若所述内存无效,则执行步骤S105。

S105.接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

实施例二

参见图2所示的一种内存的申请使用方法的流程图,该方法应用于资源池,具体包括如下步骤:

S201.接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

S202.接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

若有效,则执行步骤S203

S203.向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

接收所述任务线程发送的资源释放请求,释放所述内存,并向所述任务线程发送释放成功信息。

若无效则执行步骤S204。

S204.向所述任务线程发送资源无效信息。

实施例三

对于前述实施例所提供的内存的申请使用方法,本发明实施例提供了一种内存的申请使用装置,参见图3示的一种内存的申请使用装置的结构框图,该装置应用于任务线程,包括如下部分:

申请模块31,用于向资源池发送资源申请请求,以触发资源池分配内存;

接收模块32,用于接收所述资源池发送的内存信息,所述内存信息至少包括内存标识和内存地址;

检测模块33,用于向所述资源池发送资源使用请求,以触发所述资源池检测所述内存是否有效;

使用模块34,用于若有效,则接收所述资源池发送的资源有效信息,并使用内存。

进一步的,所述装置还包括:

释放模块35,用于向所述资源池发送释放资源请求,以触发所述资源池释放资源。

进一步的,所述装置还包括:

再次请求模块36,用于若所述内存无效,则接收所述资源池发送的资源无效信息,并再次向所述资源池请求内存。

实施例四

对于前述实施例所提供的内存的申请使用方法,本发明实施例提供了一种内存的申请使用装置,参见图4示的一种内存的申请使用装置的结构框图,该装置应用于资源池,包括如下部分:

申请请求接收模块41,用于接收所述任务线程发送的资源申请请求,向所述任务线程分配内存并发送内存信息,所述内存信息至少包括内存标识和内存地址;

使用请求接收模块42,用于接收所述任务线程发送的资源使用请求,检测所述内存是否有效;

有效信息发送模块43,用于若有效,则向任务线程发送资源有效信息,以触发所述任务线程使用所述内存。

本发明实施例还提供了一种计算机存储介质,用于储存为上述实施例提供的装置所用的计算机软件指令。

另外,在本发明实施例的描述中,除非另有明确的规定和限定,术语“安装”、“相连”、“连接”应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或一体地连接;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通。对于本领域的普通技术人员而言,可以具体情况理解上述术语在本发明中的具体含义。

在本发明的描述中,需要说明的是,术语“中心”、“上”、“下”、“左”、“右”、“竖直”、“水平”、“内”、“外”等指示的方位或位置关系为基于附图所示的方位或位置关系,仅是为了便于描述本发明和简化描述,而不是指示或暗示所指的装置或元件必须具有特定的方位、以特定的方位构造和操作,因此不能理解为对本发明的限制。

此外,术语“第一”、“第二”、“第三”仅用于描述目的,而不能理解为指示或暗示相对重要性。

需要说明的是,在本发明所提供的实施例中,应该理解到,所揭露系统和方法,可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,又例如,多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的地。

另外,在本发明提供的实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。

所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。

附图中的框图显示了根据本发明的多个实施例的系统和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图中的每个方框、以及框图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。

此外,术语“第一”、“第二”、“第三”仅用于描述目的,而不能理解为指示或暗示相对重要性。

除非另外具体说明,否则在这些实施例中阐述的部件的相对数字表达式和数值并不限制本发明的范围。

在这里示出和描述的所有示例中,任何具体值应被解释为仅仅是示例性的,而不是作为限制,因此,示例性实施例的其他示例可以具有不同的值。

最后应说明的是:以上所述实施例,仅为本发明的具体实施方式,用以说明本发明的技术方案,而非对其限制,本发明的保护范围并不局限于此,尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,其依然可以对前述实施例所记载的技术方案进行修改或可轻易想到变化,或者对其中部分技术特征进行等同替换;而这些修改、变化或者替换,并不使相应技术方案的本质脱离本发明实施例技术方案的精神和范围,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应所述以权利要求的保护范围为准。

本文发布于:2023-04-13 02:27:16,感谢您对本站的认可!

本文链接:https://patent.en369.cn/patent/3/85732.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 369专利查询检索平台 豫ICP备2021025688号-20 网站地图