Это показывает, что каждая метрика программного обеспечения имеет недостатки, если вы вслепую доводите ее до крайности.
Вы знаете «несвязный» класс, когда видите его. Например:
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;
}
Действительно, я думаю, что лучше понять, что такое сплоченность и почему это стоящая цель, но также и понять, что программный инструмент не может правильно ее измерить.