[发明专利]一种函数耗时统计方法、装置、存储介质及终端设备有效

专利信息
申请号: 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所述的函数耗时统计方法,其特征在于,所述获取所述预设执行函数的函数名和所述预设执行函数所在类的类名,并将所述预设执行函数的函数耗时与所述预设执行函数的函数名以及所述预设执行函数所在类的类名进行关联保存,包括:

获取用户预先设置的预设时长阈值;

判断所述预设执行函数的函数耗时是否大于所述预设时长阈值;

若所述预设执行函数的函数耗时大于所述预设时长阈值,则获取所述预设执行函数的函数名和所述预设执行函数所在类的类名;

将所述预设执行函数的函数耗时与所述预设执行函数的函数名以及所述预设执行函数所在类的类名进行关联保存。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201811423786.2/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top