[发明专利]一种基于回调函数建模自动生成Android应用回调序列的方法有效

专利信息
申请号: 201710029661.0 申请日: 2017-01-16
公开(公告)号: CN106874764B 公开(公告)日: 2019-10-29
发明(设计)人: 许静;过辰楷;刘奥;朱静雯;康介恢 申请(专利权)人: 南开大学
主分类号: G06F21/56 分类号: G06F21/56;G06F11/36
代理公司: 天津佳盟知识产权代理有限公司 12002 代理人: 侯力
地址: 300071*** 国省代码: 天津;12
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 基于 调函 建模 自动 生成 android 应用 序列 方法
【权利要求书】:

1.一种基于回调函数建模自动生成Android应用回调序列的方法,其特征在于含有以下步骤:

步骤1、搭建Android回调信息库;

步骤2、以Android应用的smali类型源码为输入,进行函数-回调映射预处理;

步骤3、根据生命周期时序关系,生成生命周期回调序列;

步骤4、识别注册或释放注册动作的关键连接点,生成由注册或释放注册引起的非生命周期回调序列;

步骤5、识别Activity跳转及Service跳转动作的关键连接点,生成跳转链接;

步骤6、生成由Activity跳转和Service跳转引起的非生命周期回调序列;

步骤2所述的进行函数-回调映射预处理的算法方法是,首先遍历由无用代码所构成的白名单之外的有效函数定义,标记每个函数的前驱与后继,识别搜索到的函数是否为回调函数,得到回调函数集合callbackSet以及被标记的开发者自定义的非回调函数集合funSignedSet;之后基于这两个集合,以每一个回调函数作为调用者,即前驱函数,依次搜索被调用者,即后继非回调函数,并且迭代搜索后继,直到没有后继的非回调函数,在遍历过程中,记录初始回调函数和整个搜索调用顺序从而生成函数-回调映射列表的一条记录,该列表反映每一对非回调函数与其相应的回调入口的映射关系;

步骤3所述的生成生命周期回调序列,以组件类型及组件源码作为输入,其中组件类型集合为{activity,service,receiver,other},首先为每一个组件添加三个辅助节点onActiveStart,onActiveEnd以及onTerminal,用于标识组件的如下状态:运行开始,运行结束和销毁结束,以此来显式限定组件的活动域以及跳转时机;然后生成对应组件类型的完备生命周期图ELG;之后在步骤2得到的callbackSet集合中识别类型为生命周期回调函数的元素,这些元素再添加上onActiveStart,onActiveEnd以及onTerminal三个辅助节点构成被实现的生命周期回调函数节点lifeNodes,以ELG中所有节点为全集,求lifeNodes的补集得到未被实现的生命周期回调函数隐藏节点hiddenNodes;最后对每一个hiddenNode,将其父亲节点与子节点相连,即生成父节点->子节点的序列,并删除与该hiddenNode相关的序列,最终获得的ELG即为生命周期串行回调序列;

步骤6所述的生成由Activity跳转和Service跳转引起的非生命周期回调序列,以步骤5生成的跳转链接为输入,为connection_activity类型的跳转链接生成A.onActiveEnd->B.init和B.onTerminal->A.onActiveStart的串行回调序列;为connection_service类型链接生成A.invoker->B.init的并行回调序列;为connection_stop_service类型链接生成B.onTerminal->A.的并行回调序列。

2.根据权利要求1所述的基于回调函数建模自动生成Android应用回调序列的方法,其特征在于步骤1所述的Android回调信息库包含白名单集、注册关系集、释放注册关系集、组件间跳转函数集和回调函数集。

3.根据权利要求1所述的基于回调函数建模自动生成Android应用回调序列的方法,其特征在于步骤4所述的生成由注册或释放注册引起的非生命周期回调序列,首先识别由注册或释放注册动作的关键连接点,即关键连接函数的调用语句,关键连接函数集合定义在Android回调信息库中;以函数-回调映射列表为辅助来获取该连接点的前驱回调函数;通过识别关键连接函数的参数获取后继节点集;对于每一组前驱和后继的注册回调关系,为lifecycle->non-lifecycle关系生成onActiveStart->invokee->onActiveEnd串行回调序列,其中invokee为被注册的后继回调,为non-lifecycle->non-lifecycle关系生成invoker->invokee->onActiveEnd串行回调序列,其中invoker是前驱节点。

4.根据权利要求1所述的基于回调函数建模自动生成Android应用回调序列的方法,其特征在于步骤5所述的生成跳转链接,首先识别Activity跳转动作和Service跳转动作的关键连接点;为每一个关键连接点生成跳转链接,所述跳转链接包含链接类型、关键连接点前驱回调invoker、连接点所在组件,即前驱组件A及其类型、转到的目的组件,即后继组件B及其类型七个属性,其中链接类型集合为{connection_activity,connection_service,connection_stop_service}。

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

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南开大学,未经南开大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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