查看方式:Visual Studio -> Analyze -> Calculate code metrics feature

代码度量(Code Metrics)是用来测量专业标准的软件特性。在某些方面,它提供了量化的有用反馈给开发者。

查看代码度量值很简单:在项目或解决方案上按右键,选择"Calculate Code Metrics"。 以下是一些类似的结果:

结果窗口中有五个不同的度量特性:圈复杂度(Cyclomatic Complexity), 继承深度(Depth of Inheritance), 类耦合度(Class Coupling), 代码行数(Lines of Code), 和一个总的可维护指数(Maintainability Index)。 通过展开左边的树结点,你可以从整个项目深入观察类里面的方法。

但是特征中的那些数字是什么意思呢?

圈复杂度(Cyclomatic Complexity)

圈复杂度是调用方法时取得的线性独立路径的总数,基于if,switch,while和类似的分支语句的数量。 如果一个方法没有这样的语句存在,就表示方法中只有一条可行路线,这样的情况下圈复杂度的值为1。

public int DoSomething(int x)
{
if (x == )
{
// code that is executed when x is 1
} if (x == )
{
// code that is executed when x is 2
} // code that is executed even if x is neither 1 or 2 return x;
}

在这个例子中,有三条可行的路线存在,走哪条路线取决于x的值:

1、当x是1
2、当x是2
3、当x不是1也不是2

圈复杂度告诉你两件重要事:

首先,它指出一个方法的综合复杂度。值越低越好,如果数值较高,就说明方法可能覆盖了过多不同情况的处理(例如,尝试做太多容错处理),说明方法需要分解成更简单的只满足一种情况的单一职责方法(这样会更容易维护)。

其次,为了确保每种情况都被完全地测试,你必须为每条路线创建唯一的测试用例。 圈复杂度告诉你需要写多少个测试用例来确保所有可能的情况都已经被覆盖。

如果一个代码段的圈复杂度值多于测试用例的数量,你就会发现有些情况没有被处理,而且可能藏匿着bug。

继承深度(Depth of Inheritance)

继承深度是表示一个类的继承的级数,起始值为1(所有类都是继承自Object)。 这个例子有3级继承:

该值是越低越好; 如果继承深度在3或4以上,你的代码可能超出设计标准(over-engineered),说明代码是难以维护的。

数值越高,就越多子类需要修改 -- 消耗时间和金钱,也潜在地引入bug -- 如果你对基类做出重大变更的话。

只要你考虑下每个变更对于子类会引入一些潜在的bug,这些bug会影响到他们引用的所有对象。。。 你就懂我意思了。

类耦合度(Class Coupling)

类耦合度是计算一个类中引用到的对象类型数,不包括原始的和内置的类型,像int和string。 该值是越低越好; 值越高,就代表类绑定了越多类,也意味着存在越多依赖关系在它的中间环境中。

随着类的耦合度的增加,它就会变得难以分离出来用在另一个项目中。 简单来讲,类的耦合度越高,它的重用性就越低。

我们都看过很多理论案例说类要尽量可重用,但实际编程,大部分类都是高度针对特定项目而编写的,或多或少需要完全重写才能"重用"在另一个项目中。

如果类在它最初被创建的时候设计得更完善,我们就可以在之后省掉很多时间。

代码行数(Lines of Code)

代码行数是通过计算执行的代码行数来量度软件块的大小。 虽然和上面的特征一样,这个值也是越低越好(原因很简单,你以更少的代码完成功能就能减少你思考的负担),但在用这个特征前有几条告诫你需要知道:

1、不是每行代码都相等。 有些行是非常简单,有些却非常复杂,会花费数小时来计算。
2、它不计算已删除或已覆盖的代码
3、有时将一行复杂的代码分割成几行会令它更容易理解; 在这样的情况下,增加了代码行但更容易维护。
4、除非设计完善并彻底测试过,而且已成型的所有代码是出自你本人,否则代码行数不会精确反映投入软件中的努力的量。
要聪明地使用这个度量值。 在以前,代码行数出名地被滥用于测量每日的编程生产力,带来了灾难性的结果。 请记住,比起写代码,软件开发有更多重要的东西。

可维护指数(Maintainability Index)

最后是可维护指数,范围是0到100,用来指示所有类,成员,命名空间或项目的可维护性。 事实上,它是一个之前所有度量值的合计值,但它也同时包含一些额外的度量值,像霍尔斯特德量(Halstead Volume),该值用来量度程序的总长度和词汇数。 与之前的度量值不同,这个值是越高越好。

可维护指数还提供了一个红/黄/绿的交通灯图标,让你一眼看见问题的区域。 交通灯会转黄当数值低于20,当数值低于10时会转红,这时你需要重新检查你的代码以躲避危险。

参考资料

https://blog.csdn.net/zh_geo/article/details/52954145
https://docs.microsoft.com/zh-cn/visualstudio/code-quality/code-metrics-values?view=vs-2017

关于 Visual Studio 的代码度量值的更多相关文章

  1. 通过 Visual Studio 的“代码度量值”来改进代码质量

    1 软件度量值指标 1.1 可维护性指数 表示源代码的可维护性,数值越高可维护性越好.该值介于0到100之间.绿色评级在20到100之间,表明该代码具有高度的可维护性:黄色评级在10到19之间,表示该 ...

  2. 通过Visual Studio 的“代码度量值”来改进代码质量

    1 软件度量值指标 1.1 可维护性指数 表示源代码的可维护性,数值越高可维护性越好.该值介于0到100之间.绿色评级在20到100之间,表明该代码具有高度的可维护性:黄色评级在10到19之间,表示该 ...

  3. visual studio制作代码片段

    使用 Visual Studio 的代码片段功能,我们可以快速根据已有模板创建出大量常用的代码出来.ReSharper 已经自带了一份非常好用的代码片段工具,不过使用 ReSharper 创建出来的代 ...

  4. Visual Studio 的代码片段工具

    当安装完Visual Studio之后,会有附带一些原生的代码片段文件(*.snippet),对于vs2013参考目录如下: X:\Program Files (x86)\Microsoft Visu ...

  5. Visual Studio 创建代码注释默认模版方法

    在日常的开发中我们经常需要为页面添加注释和版权等信息,这样我们就需要每次去拷贝粘贴同样的文字,为了减少这种重复性的工作,我们可以把这些信息保存在Visual Studio 2012类库模版文件里 1. ...

  6. [搬运] 将 Visual Studio 的代码片段导出到 VS Code

    原文 : A Visual Studio to Visual Studio Code Snippet Converter 作者 : Rick Strahl 译者 : 张蘅水 导语 和原文作者一样,水弟 ...

  7. 【转】VISUAL STUDIO 2008代码指标为您节省资金

    转自:https://www.geekzone.co.nz/vs2008/4773 Visual Studio 2008 Team Developer和Team Suite版本中提供的许多新功能之一是 ...

  8. Visual Studio模板代码注释小技巧分享

    在日常开发过程中,难免有这样一种需求:就是你所建的每一个类文件或者接口文件都需要标注下作者姓名以及类的用途.如果我们每次创建文件的时候都需要写一遍这些信息是很烦神的.还好Visual Studio给我 ...

  9. Visual Studio模板代码注释小技巧

    在日常开发过程中,难免有这样一种需求:就是你所建的每一个类文件或者接口文件都需要标注下作者姓名以及类的用途.如果我们每次创建文件的时候都需要写一遍这些信息是很烦神的.还好Visual Studio给我 ...

随机推荐

  1. Pytest权威教程12-跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例

    目录 跳过(Skip)及预期失败(xFail): 处理不能成功的测试用例 Skip跳过用例 xFail:将测试函数标记为预期失败 Skip/xFail参数设置 返回: Pytest权威教程 跳过(Sk ...

  2. 多个List 或 Array 进行 合并

    1.调用 var aaa = new List<string>() { "0" }; var a1 = new List<string>() { " ...

  3. Coupled和segregated【转载】

    转载自:http://blog.sina.com.cn/s/blog_67873f6c0100ltq6.html 问题1: 我看中文帮组里说是'分离'的意思?我绝对翻译不太好,请问有更好的翻译吗? 和 ...

  4. js检测手机上是否有此APP,有的话打开应用,没有的话跳转到appstore

    //html代码中 的 a 标签,以微信为例,默认的是调用weixin scheme,去打开本机的微信,如果没有则跳转到相应连接 <a href="weixin://" cl ...

  5. IIS错误代码500.21 ,Nhibernate更新报错,委托的使用。action传参数

    快速阅读 IIS错误代码500.21 ,Nhibernate更新报错,委托的使用.action传参数 IIS错误代码500.21 HTTP 错误 500.21 - Internal Server Er ...

  6. 部署gerrit环境完整记录【转】

    开发同事提议在线上部署一套gerrit代码审核环境,废话不多说,部署gerrit的操作记录如下:提前安装好java环境,mysql环境,nginx环境测试系统:centos6.5下载下面三个包,放到/ ...

  7. Java性能分析神器-JProfiler详解(转)

    前段时间在给公司项目做性能分析,从简单的分析Log(GC log, postgrep log, hibernate statitistic),到通过AOP搜集软件运行数据,再到PET测试,感觉时间花了 ...

  8. python,在路径中引用变量的方法

    fr = open('E:\\pyCharm\\LogisticRegression\\1\\'+变量+'.txt')

  9. ionic4.x网络请求

    创建common服务: import { Injectable } from '@angular/core'; import { HttpClient } from '@angular/common/ ...

  10. nginx奔溃自动重启Shell脚本

    # vi /usr/local/nginx/sbin/nginx_restart.sh 贴入一下代码: #!/bin/bash #www.xmsolink.com #Monitor nginx ser ...