[发明专利]软件代码复杂度的检测方法、装置及电子设备在审
申请号: | 201810590045.7 | 申请日: | 2018-06-08 |
公开(公告)号: | CN110580218A | 公开(公告)日: | 2019-12-17 |
发明(设计)人: | 邓水光;傅珉;智晨;陈曦;尹建伟;李元平;朱海 | 申请(专利权)人: | 浙江大学 |
主分类号: | G06F11/36 | 分类号: | G06F11/36;G06F8/41 |
代理公司: | 11353 北京市惠诚律师事务所 | 代理人: | 杨娟;杨雪婷 |
地址: | 310013 浙*** | 国省代码: | 浙江;33 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 聚合 复杂度 代码片段 复杂度检测 评估软件 装置及电子设备 人员定位 软件代码 检测 回溯 输出 评估 开发 | ||
1.一种软件代码复杂度的检测方法,其特征在于,包括:
获取待评估软件的多个代码片段的代码复杂度指标;
对所述多个代码片段的代码复杂度指标进行逐级纵向聚合,得到第一聚合得分;
对所述第一聚合得分横向聚合,得到第二聚合得分,将所述第二聚合得分作为所述代码复杂度输出。
2.根据权利要求1所述的方法,其特征在于,所述代码复杂度指标包括:
多个维度的method类型指标和/或多个维度的type类型指标。
3.根据权利要求1所述的方法,其特征在于,所述逐级纵向聚合包括:
按照类层、文件层、模块层以及项目层中的任意多个层的层级顺序,进行纵向聚合,得到所述第一聚合得分。
4.根据权利要求1所述的方法,其特征在于,对所述多个代码片段的代码复杂度指标进行逐级纵向聚合包括:
使用弱项集约式聚合函数对所述多个代码片段的代码复杂度指标进行逐级纵向聚合。
5.根据权利要求4所述的方法,其特征在于,所述弱项集约式聚合函数为:
其中,f(x)为纵向聚合所针对的层级的整体的聚合得分,xi为纵向聚合所针对层级的各个被聚合单位的聚合得分或者代码复杂度指标。
6.根据权利要求1所述的方法,其特征在于,所述对所述第二聚合得分横向聚合,得到第二聚合得分,包括:
计算所述第一聚合得分的平均值,得到所述第二聚合得分。
7.根据权利要求1所述的方法,其特征在于,在逐级纵向聚合的过程中,对各层级对应的聚合得分进行调整,以对抗长尾分布效应。
8.一种软件代码复杂度的检测装置,其特征在于,包括:
代码复杂度指标获取模块,用于获取待评估软件的代码片段的代码复杂度指标;
纵向聚合模块,用于对所述多个代码片段的代码复杂度指标进行逐级纵向聚合,得到第一聚合得分;
横向聚合模块,用于对所述第一聚合得分横向聚合,得到第二聚合得分,将所述第二聚合得分作为所述代码复杂度输出。
9.根据权利要求8所述的装置,其特征在于,对所述多个代码片段的代码复杂度指标进行逐级纵向聚合包括:
使用弱项集约式聚合函数对所述多个代码片段的代码复杂度指标进行逐级纵向聚合。
10.一种电子设备,其特征在于,包括:
存储器,用于存储程序;
处理器,耦合至所述存储器,用于执行所述程序,以用于:
获取待评估软件的多个代码片段的代码复杂度指标;
对所述多个代码片段的代码复杂度指标进行逐级纵向聚合,得到第一聚合得分;
对所述第一聚合得分横向聚合,得到第二聚合得分,将所述第二聚合得分作为所述代码复杂度输出。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于浙江大学,未经浙江大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810590045.7/1.html,转载请声明来源钻瓜专利网。