java sourcemonitor圈复杂度计算

转载文章


sourcemonitor集成至eclipse的方法:

  
1、安装sourcemonitor工具  

2、run New_Configration菜单 -> External Tools Configurations..  

     设置参数:/DJava${container_loc}/${resource_name}  


圈复杂度(Cyclomatic Complexity)是一种代码复杂度的衡量标准。它可以用来衡量一个模块判定结构的复杂程度,数量上表现为独立现行路径条数,
也可理解为覆盖所有的可能情况最少使用的测试用例数。圈复杂度大说明程序代码的判断逻辑复杂,可能质量低且难于测试和维护。程序的可能错误
和高的圈复杂度有着很大关系。
下面这个实例中,单元测试的覆盖率可以达到100%,但是很容易发现这其中已经漏掉了一个NPE的测试用例。case1方法的圈复杂度为2,因此至少需要
2个用例才能完全覆盖到其所有的可能情况。
//程序原代码,圈复杂度为 2
public String case1(int num) {
       String string = null;
       if (num == 1) {
           string = "String";
       }
       return string.substring(0);
    }
 //上面代码的单元测试代码
    public void testCase1(){
       String test1 = case1(1);
    }





圈复杂度主要与分支语句(if、else、,switch 等)的个数成正相关。可以在图1中看到常用到的几种语句的

控制流图(表示程序执行流程的有向图)。  当一段代码中含有较多的分支语句,其逻辑复杂程度就会增加。

在计算圈复杂度时可以通过程序控制流图方便的计算出来。通常使用的计算公式是  V(G) = e – n + 2  e代表

在控制流图中的边的数量(对应代码中顺序结构的部分),n 代表在控制流图中的节点数量,包括起点和终点 

(1、所有终点只计算一次,即便有多个return或者throw;2、节点对应代码中的分支语句) 



知道了如何计算圈复杂度,我们来使用控制流图重新计算一次case1方法的圈复杂度,其控制流图如下图。
状态1表示 if(num == 1 )的条件判断,  状态2表示string=”String”的赋值操作。可以通过下面的控
制流图得到 e = 4 ; n = 4;那么全复杂度V(G) = 4 - 4 + 2 = 2,既case1的圈复杂度为2

public String case2(int index, String string) {  
       String returnString = null;  
       if (index < 0) {  
           throw new IndexOutOfBoundsException("exception <0 ");  
       }  
       if (index == 1) {  
           if (string.length() < 2) {  
              return string;  
           }  
           returnString = "returnString1";  
       } else if (index == 2) {  
           if (string.length() < 5) {  
              return string;  
           }  
           returnString = "returnString2";  
       } else {  
           throw new IndexOutOfBoundsException("exception >2 ");  
       }  
       return returnString;  
    }  


根据公式 V(G) = e – n + 2 = 12 – 8 + 2 = 6 。case2的圈复杂段为6。说明一下为什么n = 8,
虽然图上的真正节点有12个,但是其中有5个节点为throw、return,这样的节点为end节点,

只能记做一个在开发中常用的检测圈复杂度的工具,PMD,checkstyle ,sourcemonitor都可以检

测到高复杂度的代码块。在代码的开发中,配合各种圈复杂度的检测插件,将高复杂度的代码

进行适当的拆分、优化,可以大大提高代码整体的质量,减少潜在bug存在。  


另外,提下/DJava${container_loc}/${resource_name},可以参考博文[container_loc]  

百度文库资料[外部工具作为项目构建进程的一部分]

eclipse所有的插件都会在showView展示出来,比如eclipses->svn插件,当我们要清除

svn插件中记录的svn目录时,可以在showView中找出svn,然后remove repository

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值