[发明专利]一种函数耗时统计方法、装置、存储介质及终端设备有效
申请号: | 201811423786.2 | 申请日: | 2018-11-27 |
公开(公告)号: | CN109634822B | 公开(公告)日: | 2023-04-14 |
发明(设计)人: | 何兵 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
主分类号: | G06F11/34 | 分类号: | G06F11/34;G06F11/36 |
代理公司: | 深圳中一专利商标事务所 44237 | 代理人: | 高星 |
地址: | 518000 广东省深圳市福田区福*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 函数 耗时 统计 方法 装置 存储 介质 终端设备 | ||
1.一种函数耗时统计方法,其特征在于,包括:
获取指定项目的项目路径;
根据所述项目路径和预设类名获取方法,获取所述指定项目中的各类和各类的类名;
分别将各类的类名作为第一参数,利用预设函数获取方法以及所述第一参数,得到各类中的执行函数,并将所述执行函数确定为所述指定项目的预设执行函数,包括:依次将各类的类名分别作为第一参数传入至class_copyMethodList方法中,得到class_copyMethodList方法执行后分别返回的返回结果,其中,所述返回结果为对应类中的所有函数,所获取的函数包括函数名、函数类型和所属函数所对应的函数指针;
获取所述预设执行函数的第一函数指针,并将所述第一函数指针替换为预设函数指针,其中,所述预设函数指针用于触发执行预设消息转发函数;
创建与所述预设执行函数相对应的目标执行函数,并将所述目标执行函数的第二函数指针设置为对应的预设执行函数的第一函数指针;
在执行预设执行函数时,跳转至执行预设消息转发函数;
通过所述预设消息转发函数调用第一时间获取函数,获取第一时间;
在所述第一时间获取函数执行完毕后,通过所述预设消息转发函数调用与所述预设执行函数相对应的目标执行函数,所述目标执行函数被用于进行所述预设执行函数的还原执行,包括:在跳转至执行预设消息转发函数时,从所组装的NSInvocation对象中反解出所述预设执行函数所对应的第二参数,记录跳转之前所执行的所述预设执行函数以及所对应的第二参数;从预先创建的多个目标执行函数中确定与所述预设执行函数相对应的目标执行函数,并将所述第二参数传入所述目标执行函数中;通过所述预设消息转发函数调用传入所述第二参数后的目标执行函数,以实现所述预设执行函数的还原执行;
在所述目标执行函数执行完毕后,通过所述预设消息转发函数调用第二时间获取函数,获取第二时间;
根据所述第一时间和所述第二时间,统计得到所述预设执行函数的函数耗时。
2.根据权利要求1中任一项所述的函数耗时统计方法,其特征在于,在根据所述第一时间和所述第二时间,统计得到所述预设执行函数的函数耗时之后,包括:
获取所述预设执行函数的函数名和所述预设执行函数所在类的类名,并将所述预设执行函数的函数耗时与所述预设执行函数的函数名以及所述预设执行函数所在类的类名进行关联保存。
3.根据权利要求2所述的函数耗时统计方法,其特征在于,所述获取所述预设执行函数的函数名和所述预设执行函数所在类的类名,并将所述预设执行函数的函数耗时与所述预设执行函数的函数名以及所述预设执行函数所在类的类名进行关联保存,包括:
获取用户预先设置的预设时长阈值;
判断所述预设执行函数的函数耗时是否大于所述预设时长阈值;
若所述预设执行函数的函数耗时大于所述预设时长阈值,则获取所述预设执行函数的函数名和所述预设执行函数所在类的类名;
将所述预设执行函数的函数耗时与所述预设执行函数的函数名以及所述预设执行函数所在类的类名进行关联保存。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811423786.2/1.html,转载请声明来源钻瓜专利网。