20

我正在查看此处显示的 LCOM 指标,

http://www.ndepend.com/Metrics.aspx

所以我们要说几件事,

1) A class is utterly cohesive if all its methods use all its instance fields
2) Both static and instance methods are counted, it includes also constructors, properties getters/setters, events add/remove methods

如果我看这样的课程,

public class Assessment
{
    public int StartMetres { get; set; }
    public int EndMetres { get; set; }
    public decimal? NumericResponse { get; set; }
    public string FreeResponse { get; set; }
    public string Responsetype { get; set; }
    public string ItemResponseDescription { get; set; }
    public string StartText { get; set; }
    public decimal? SummaryWeight { get; set; }
}

它的得分为 0.94,因为每个 getter 和 setter 都不能访问“所有其他实例字段”。

是这样计算的,

accessAverage - methodCount / 1 - methodCount

(2 - 17) / (1 - 17) = 0.94 (rounded)

我不理解这个指标,为什么它应该包括 getter 和 setter?getter 和 setter 将始终只访问一个实例字段。

4

1 回答 1

26

这表明,如果您盲目地将其发挥到极致,那么每个软件指标都是有缺陷的。

当你看到一个“不连贯”的课程时,你就知道了。例如:

class HedgeHog_And_AfricanCountry
{

   private HedgeHog _hedgeHog;
   private Nation _africanNation;

   public ulong NumberOfQuills { get { return _hedgeHog.NumberOfQuills; } }
   public int CountOfAntsEatenToday { get { return _hedgeHog.AntsEatenToday.Count(); } }

   public decimal GrossDomesticProduct { get { return _africanNation.GDP; } }
   public ulong Population { get { return _africanNation.Population; } }
}

这显然是一个没有凝聚力的类,因为它包含两条不需要相互关联的数据。

但是,虽然对我们来说很明显这个类是不连贯的,但是你怎么能得到一个软件程序来确定不连贯呢?它如何判断上面的类是没有凝聚力的,但事实并非如此?

class Customer
{
    public string FullName { get; set; }
    public Address PostalAddress { get; set; }
} 

他们提出的指标肯定会检测到不凝聚力,但也会出现误报。

如果你认为这个指标很重要怎么办?您可以创建一个仅包含字段的“CustomerData”类,以及一个将数据字段作为属性公开的“Customer”类。

// This has no methods or getters, so gets a good cohesion value.
class CustomerData
{
    public string FullName;
    public Address PostalAddress;
}

// All of the getters and methods are on the same object
class Customer
{
   private CustomerData _customerData;
   public string FullName { get { return _customerData.FullName; } }
   // etc
}

但是如果我在玩这个游戏,我也可以将它应用到不连贯的例子中:

class Hedgehog_And_AfricanCountry_Data
{
   public Hedgehog _hedgehog;
   public AfricanNation _africanNation;
}

class Hedgehog_And_AfricanCountry
{
   private Hedgehog_And_AfricanCountry_Data _hedgehogAndAfricanCountryData;
   // etc;
}

真的,我认为最好了解什么是凝聚力,以及为什么它是一个值得的目标,但也要了解软件工具无法正确衡量它。

于 2011-05-16T04:21:07.277 回答