Почему отсутствие единства методов (LCOM) включает геттеры и сеттеры - PullRequest
20 голосов
/ 16 мая 2011

Я смотрю на показатель 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, потому что каждый метод получения и установки не имеет доступа ко «всем другим полям экземпляра».

Он рассчитывается следующим образом:

accessAverage - methodCount / 1 - methodCount

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

Я не понимаю эту метрику, почему она должна включать геттеры и сеттеры?Получатель и установщик всегда будут иметь доступ только к одному полю экземпляра.

1 Ответ

26 голосов
/ 16 мая 2011

Это показывает, что каждая метрика программного обеспечения имеет недостатки, если вы вслепую доводите ее до крайности.

Вы знаете «несвязный» класс, когда видите его. Например:

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;
}

Действительно, я думаю, что лучше понять, что такое сплоченность и почему это стоящая цель, но также и понять, что программный инструмент не может правильно ее измерить.

...