一种获取堆栈使用量的方法及装置制造方法及图纸

技术编号:24755511 阅读:59 留言:0更新日期:2020-07-04 09:01
本申请是关于一种获取堆栈使用量的方法及装置,属于计算机领域。所述方法包括:在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。本申请能够避免机器死机或跑飞的问题。

A method and device for obtaining stack usage

【技术实现步骤摘要】
一种获取堆栈使用量的方法及装置
本申请涉及计算机领域,特别涉及一种获取堆栈使用量的方法及装置。
技术介绍
堆栈是在计算机领域中经常使用的一种抽象数据结构,堆栈具有后进先出的特性,该特性是指最后一个放入堆栈中的数据总是最先从堆栈拿出来。基于该后进先出的特性,目前各种程序中常常通过堆栈保存程序中各函数的调用关系。目前有人提出,依据编译出可执行文件内的反汇编代码来推断,在熟知CPU体系(X86\ARM\PPC\MIPS等)汇编源码及堆栈结构特点的前提下,分析每个函数占用的最大堆栈数值,往往这种分析得到的是一个堆栈使用范围,按照最大堆栈数值计算是比较保守的,不够准确。专利技术人在实现本申请的过程中,发现上述方式至少存在如下缺陷:由于估计的使用量不够准确,当估计的使用量小于实际使用量时,函数在该CPU(X86\ARM\PPC\MIPS等)运行时就会现堆栈溢出,导致机器死机或跑飞的问题。
技术实现思路
为了避免在将程序部署在处理器运行时出现堆栈溢出,机器死机或跑飞的问题,本申请实施例提供了一种获取堆栈使用量的方法及装置。所述技术方案如下:根据本申请实施例的第一方面,提供一种获取堆栈使用量的方法,所述方法包括:在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。可选的,所述在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,包括:在程序包括的目标函数对应的检测入口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;读取所述确定的空间内保存的第一数据。可选的,所述在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据,包括:在所述检测出口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;读取所述确定的空间内保存的第二数据。可选的,所述根据所述第一数据和所述第二数据确定所述函数使用所述堆栈的使用量,包括:比较所述第一数据和所述第二数据,得到所述第一数据中的与所述第二数据不同的差异数据;将所述差异数据的数据量确定为所述函数使用所述堆栈的使用量。可选的,所述目标函数为所述主函数直接或非直接调用的子函数。可选的,所述根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量之后,还包括:从所述程序包括的函数使用所述堆栈的使用量中选择最大使用量,将所述最大使用量和所述主函数使用所述堆栈的使用量相加,得到所述程序使用所述堆栈的使用量。根据本申请实施例的第二方面,提供一种获取堆栈使用量的装置,所述装置包括:第一获取模块,用于在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;第二获取模块,用于在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;确定模块,用于根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。可选的,所述第一获取模块,用于:在程序包括的目标函数对应的检测入口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;读取所述确定的空间内保存的第一数据。可选的,所述第二获取模块,用于:在所述检测出口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;读取所述确定的空间内保存的第二数据。可选的,所述确定模块,用于:比较所述第一数据和所述第二数据,得到所述第一数据中的与所述第二数据不同的差异数据;将所述差异数据的数据量确定为所述函数使用所述堆栈的使用量。可选的,所述目标函数为所述主函数直接或非直接调用的子函数。可选的,所述装置还包括:选择模块,用于从所述程序包括的函数使用所述堆栈的使用量中选择最大使用量,将所述最大使用量和所述主函数使用所述堆栈的使用量相加,得到所述程序使用所述堆栈的使用量。根据本申请实施例的第三方面,提供一种计算机可读存储介质,所述计算机可读存储介质内存储有计算机程序,所述计算机程序被处理器执行时实现所述第一方面或第一方面任可选的方式提供的方法步骤。根据本申请实施例的第四方面,提供一种计算机设备,包括:处理器;用于存储处理器可执行指令的存储器;其中,所述处理器被配置为实现上述第一方面或第一方面任可选的方式提供的方法步骤。本申请实施例提供的技术方案可以包括以下有益效果:由于程序包括位置相邻的目标函数对应的检测入口语句、用于调用函数的调用语句和检测出口语句,检测入口语句位于该调用语句之前,检测出口语句位于该调用语句之后,这样在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被程序占用的空间内保存的第一数据,在目标函数对应的检测出口语句运行时,获取堆栈当前未被程序占用的空间内保存的第二数据,从而基于第一数据和第二数据确定目标函数使用堆栈的使用量。这样根据该使用量调整处理器分配的堆栈空间大小或优化目标函数,从而可以避免在将该程序部署在处理器运行时出现堆栈溢出,机器死机或跑飞的问题。应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。附图说明此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本申请的实施例,并与说明书一起用于解释本申请的原理。图1是本申请实施例提供的一种堆栈结构示意图;图2是本申请实施例提供的存入函数1的堆栈数据后的堆栈状态示意图;图3是本申请实施例提供的存入函数2的堆栈数据后的堆栈状态示意图;图4是本申请实施例提供的出栈函数2的堆栈数据后的堆栈状态示意图;图5是本申请实施例提供的一种获取堆栈使用量的方法流程图;图6是本申请实施例提供的另一种获取堆栈使用量的方法流程图;图7是本申请实施例提供的出栈函数1的堆栈数据后的堆栈状态示意图;图8是本申请实施例提供的一种获取堆本文档来自技高网...

【技术保护点】
1.一种获取堆栈使用量的方法,其特征在于,所述方法包括:/n在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;/n在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;/n根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。/n

【技术特征摘要】
1.一种获取堆栈使用量的方法,其特征在于,所述方法包括:
在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;
在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;
根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。


2.如权利要求1所述的方法,其特征在于,所述在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,包括:
在程序包括的目标函数对应的检测入口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第一数据。


3.如权利要求1所述的方法,其特征在于,所述在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据,包括:
在所述检测出口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第二数据。


4.如权利要求1至3任一项所述的方法,其特征在于,所述根据所述第一数据和所述第二数据确定所述函数使用所述堆栈的使用量,包括:
比较所述第一数据和所述第二数据,得到所述第一数据中的与所述第二数据不同的差异数据;
将所述差异数据的数据量确定为所述函数使用所述堆栈的使用量。


5.如权利要求1至3任一项所述的方法,其特征在于,所述目标函数为所述主函数直接或非直接调用的子函数。


6.如权利要求1至3任一项所述的方法,其特征在于,所述根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量之后,还包括:
从所述程序包括的函数使用所述堆栈的使用量中选择最大使用量,将所述最大使用量和所述主函数使用所述堆栈的使用量相加,得到所述程序使用所述堆栈的使用量。


7.一种获取堆栈使用量的装置,其特征在于,所述装置包括:
第...

【专利技术属性】
技术研发人员:倪晶静谢春宁刘有文
申请(专利权)人:杭州海康威视数字技术股份有限公司
类型:发明
国别省市:浙江;33

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1