[发明专利]一种获取堆栈使用量的方法及装置有效
申请号: | 201811593715.7 | 申请日: | 2018-12-25 |
公开(公告)号: | CN111367588B | 公开(公告)日: | 2023-05-16 |
发明(设计)人: | 倪晶静;谢春宁;刘有文 | 申请(专利权)人: | 杭州海康威视数字技术股份有限公司 |
主分类号: | G06F9/448 | 分类号: | G06F9/448;G06F9/30 |
代理公司: | 北京三高永信知识产权代理有限责任公司 11138 | 代理人: | 韩东艳 |
地址: | 310051 浙江省*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 获取 堆栈 使用 方法 装置 | ||
本申请是关于一种获取堆栈使用量的方法及装置,属于计算机领域。所述方法包括:在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。本申请能够避免机器死机或跑飞的问题。
技术领域
本申请涉及计算机领域,特别涉及一种获取堆栈使用量的方法及装置。
背景技术
堆栈是在计算机领域中经常使用的一种抽象数据结构,堆栈具有后进先出的特性,该特性是指最后一个放入堆栈中的数据总是最先从堆栈拿出来。基于该后进先出的特性,目前各种程序中常常通过堆栈保存程序中各函数的调用关系。
目前有人提出,依据编译出可执行文件内的反汇编代码来推断,在熟知CPU体系(X86\ARM\PPC\MIPS等)汇编源码及堆栈结构特点的前提下,分析每个函数占用的最大堆栈数值,往往这种分析得到的是一个堆栈使用范围,按照最大堆栈数值计算是比较保守的,不够准确。
发明人在实现本申请的过程中,发现上述方式至少存在如下缺陷:
由于估计的使用量不够准确,当估计的使用量小于实际使用量时,函数在该CPU(X86\ARM\PPC\MIPS等)运行时就会现堆栈溢出,导致机器死机或跑飞的问题。
发明内容
为了避免在将程序部署在处理器运行时出现堆栈溢出,机器死机或跑飞的问题,本申请实施例提供了一种获取堆栈使用量的方法及装置。所述技术方案如下:
根据本申请实施例的第一方面,提供一种获取堆栈使用量的方法,所述方法包括:
在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,所述程序包括位置相邻的所述目标函数对应的检测入口语句、用于调用所述目标函数的调用语句和所述目标函数对应的检测出口语句,所述检测入口语句位于所述调用语句之前,所述检测出口语句位于所述调用语句之后,所述目标函数为所述程序中除主函数外的其他函数;
在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据;
根据所述第一数据和所述第二数据确定所述目标函数使用所述堆栈的使用量。
可选的,所述在程序包括的目标函数对应的检测入口语句运行时,获取堆栈当前未被所述程序占用的空间内保存的第一数据,包括:
在程序包括的目标函数对应的检测入口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第一数据。
可选的,所述在所述检测出口语句运行时,获取所述堆栈当前未被所述程序占用的空间内保存的第二数据,包括:
在所述检测出口语句运行时,确定以所述堆栈的栈指针指向的地址为起始地址且以所述堆栈的系统栈顶为终止地址的空间;
读取所述确定的空间内保存的第二数据。
可选的,所述根据所述第一数据和所述第二数据确定所述函数使用所述堆栈的使用量,包括:
比较所述第一数据和所述第二数据,得到所述第一数据中的与所述第二数据不同的差异数据;
将所述差异数据的数据量确定为所述函数使用所述堆栈的使用量。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于杭州海康威视数字技术股份有限公司,未经杭州海康威视数字技术股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811593715.7/2.html,转载请声明来源钻瓜专利网。
- 上一篇:压缩机以及空调
- 下一篇:一种通信网络的接入方法及装置