【技术实现步骤摘要】
一种获取堆栈使用量的方法及装置
本申请涉及计算机领域,特别涉及一种获取堆栈使用量的方法及装置。
技术介绍
堆栈是在计算机领域中经常使用的一种抽象数据结构,堆栈具有后进先出的特性,该特性是指最后一个放入堆栈中的数据总是最先从堆栈拿出来。基于该后进先出的特性,目前各种程序中常常通过堆栈保存程序中各函数的调用关系。目前有人提出,依据编译出可执行文件内的反汇编代码来推断,在熟知CPU体系(X86\ARM\PPC\MIPS等)汇编源码及堆栈结构特点的前提下,分析每个函数占用的最大堆栈数值,往往这种分析得到的是一个堆栈使用范围,按照最大堆栈数值计算是比较保守的,不够准确。专利技术人在实现本申请的过程中,发现上述方式至少存在如下缺陷:由于估计的使用量不够准确,当估计的使用量小于实际使用量时,函数在该CPU(X86\ARM\PPC\MIPS等)运行时就会现堆栈溢出,导致机器死机或跑飞的问题。
技术实现思路
为了避免在将程序部署在处理器运行时出现堆栈溢出,机器死机或跑飞的问题,本申请实施例提供了一种获取堆栈使用量的方法及装置。所述技术方案如下:根据本申请实施例的第一方面,提供一种获取堆栈使用量的方法,所述方法包括:在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口 ...
【技术保护点】
1.一种获取堆栈使用量的方法,其特征在于,所述方法包括:/n在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;/n在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;/n根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。/n
【技术特征摘要】
1.一种获取堆栈使用量的方法,其特征在于,所述方法包括:
在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;
在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;
根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。
2.如权利要求1所述的方法,其特征在于,所述在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,包括:
在程序包括的目标函数对应的检测入口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第一数据。
3.如权利要求1所述的方法,其特征在于,所述在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据,包括:
在所述检测出口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第二数据。
4.如权利要求1至3任一项所述的方法,其特征在于,所述根据所述第一数据和所述第二数据确定所述函数使用所述堆栈的使用量,包括:
比较所述第一数据和所述第二数据,得到所述第一数据中的与所述第二数据不同的差异数据;
将所述差异数据的数据量确定为所述函数使用所述堆栈的使用量。
5.如权利要求1至3任一项所述的方法,其特征在于,所述目标函数为所述主函数直接或非直接调用的子函数。
6.如权利要求1至3任一项所述的方法,其特征在于,所述根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量之后,还包括:
从所述程序包括的函数使用所述堆栈的使用量中选择最大使用量,将所述最大使用量和所述主函数使用所述堆栈的使用量相加,得到所述程序使用所述堆栈的使用量。
7.一种获取堆栈使用量的装置,其特征在于,所述装置包括:
第...
【专利技术属性】
技术研发人员:倪晶静,谢春宁,刘有文,
申请(专利权)人:杭州海康威视数字技术股份有限公司,
类型:发明
国别省市:浙江;33
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。