Набор метрик Чидамбера И Кемерера
В 1994 году С. Чидамбер и Л. Кемерер предложили 6 проектных метрик, ориентированных на классы. Класс - фундаментальный элемент О-О системы. Поэтому измерения и метрики для отдельного класса, иерархии классов бесценны для программного инженера, который должен оценить качество проекта.
Набор Чидамбера – Кемерера наиболее часто цитируется в программной индустрии и научных исследованиях. Рассмотрим каждую из метрик набора.
Метрика 1: ВЗВЕШЕННЫЕ МЕТОДЫ НА КЛАСС WMC(Weughted Methods Per Class)
Допустим, что в классе С определенны n методов со сложностью с1,с2,…сn.Для оценки сложности может быть выбрана любая метрика сложности (например, цикломатическая сложность). Главное - нормализовать эту метрику так, чтобы номинальная сложность для метода принимала значение 1. В этом случае
n
WMC=∑Ci.
i=1
Количество методов и их сложность являются индикатором затрат на реализацию и тестирование классов. Кроме того, чем больше методов, тем сложнее дерево наследования(все подклассы наследуют методы их родителей).С ростом количества методов в классе его применение становится все более специфическим, тем самым ограничивается возможность многократного использования. По этим причинам метрика WMC должна иметь разумно низкое значение. Очень часто применяют упрощенную версию метрики. При этом полагают Ci=1, и тогда WMC-количество методов в классе.
Оказывается, что подсчитывать количество методов в классе достаточно сложно.
Возможно 2 противоположных варианта учета.
1) Подсчитываются только методы текущего класса. Унаследованные методы игнорируются. Обоснование - унаследованные методы уже подсчитаны в тех классах, где они определялись.
2) Подсчитываются методы, определенные в текущем классе, и все унаследованные методы. Этот подход подчеркивает важность пространства состояний в понимании класса.
На практике приемлем любой из описанных вариантов. Главное - не менять вариант учета от проекта к проекту. Только в этом случае обеспечивается корректный сбор метрических данных.
Метрика WMC дает относительную меру сложности класса. Если считать, что все методы имеют одинаковую сложность, то это будет просто количество методов в классе. Существуют рекомендации по сложности методов. Например, М. Лоренц считает, средняя длина метода должна ограничиваться 8 строками для Smalltalk и 24 строками для С++. Вообще, класс, имеющий максимальное количество методов среди классов одного с ним уровня, является наиболее сложным; скорее всего, он специфичен для данного приложения и содержит наибольшее количество ошибок.
Метрика 2: ВЫСОТА ДЕРЕВА НАСЛЕДОВАНИЯ DIT(Depth of inheritance Tree).
DIT определяется как длина пути от листа до корня дерева наследования классов. Для показанной на рис.1 иерархии классов метрика DIT равна 3.
Рис.1 Дерево наследования классов.
Соответственно, для отдельного класса DIT , это длина максимального пути от данного класса до корневого класса в иерархии классов.
ПО мере роста DIT вероятно, что классы нижнего уровня будут наследовать много методов. Это приводит к трудностям в предсказании поведения класса. Вместе с тем, большое значение DIT подразумевает , что многие методы могут использоваться многократно.
Метрика 3:КОЛИЧЕСТВО ДЕТЕЙ NOC( NUMBER OF CHILDREN)
Подклассы которые непосредственно подчинены суперклассу, называются его детьми. Значение NOC равно количеству детей, то есть количеству непосредственных наследников класса в иерархии классов. На рис.1 класс С2 имеет двух детей-подклассы С21 и С22. С увеличением NOC возрастает многократность использования, так как наследование-это форма повторного использования. Однако при возрастании NOC ослабляется абстракция родительского класса. Это означает, что в действительности некоторые из детей уже не являются членами родительского класса и могут быть неправильно использованы. Кроме того, количество детей характеризует потенциальное влияние класса на проект. По мере роста NOC возрастает количество тестов, необходимых для проверки каждого ребенка.
Метрики DIT и NOC - количественные характеристики формы и размера структуры классов. Хорошо структурированная О-О система чаще бывает организованна как лес классов, чем как сверхвысокое дерево. По мнению Г. Буча, следует строить сбалансированные по высоте и ширине структуры наследования: обычно не выше, чем 7+-2 уровня, и не шире, чем 7+-2 ветви.
Метрика 4:СЦЕПЛЕНИЕ МЕЖДУ КЛАССАМИ ОБЪЕКТОВ СВО (Cjupling between object classes)
CВО - это количество сотрудников, предусмотренных для класса, то есть количество классов, с которыми он соединен. Соединение означает, что методы данного класса используют методы или экземплярные переменные другого класса.
Другое определение метрики имеет следующий вид: СВО равно количеству сцеплений класса; сцепление образует вызов метода и его свойства в другом классе. Данная метрика характеризует статическую составляющую внешних связей классов.С ростом СВО многократность использования класса, вероятно, уменьшается. Очевидно, что чем больше независимость класса, тем легче его повторно использовать в другом приложении.
Высокое значение СВО усложняет модификацию и тестирование, которое следует за выполнением модификаций. Понятно, что , чем больше количество сцеплений , тем выше чувствительность всего проекта к изменениям в отдельных его частях. Минимизация меж-объектных сцеплений улучшает модульность и содействует инкапсуляции проекта. СВО для каждого класса должно иметь разумно низкое значение. Это согласуется с рекомендациями по уменьшению сцепления стандартного программного обеспечения.
Метрика 5:ОТКЛИК ДЛЯ КЛАССА RFC(Response For a Class)
Введем вспомогательное определение. Множество отклика класса RS-это множество методов, которые могут выполнять в ответ на прибытие сообщение в объект этого класса. Формула для определения RS имеет вид:
RS={M}Uall-i{R},
где{Ri}-множество методов, вызываемых методом i, {M}-множество всех методов в классе. Метрика RFC равна количеству методов во множестве отклика, то есть равна мощности этого множества:
RFC=card{RS}.
Данная метрика характеризует динамическую составляющую внешних связей классов. Если в ответ на сообщение может быть вызвано большое количество методов, то усложняются тестирование и отладка класса, так как разработчика тестов требуется больший уровень понимания класса, растет длина тестовой последовательности.
С ростом RFC увеличивается сложность класса. Наихудшая величина отклика может использоваться при определении времени тестирования.
Метрика 6:НЕДОСТАТОК СВЯЗНОСТИ В МЕТОДАХ LCOM(Lack of Cohesion in Methods)
Каждый метод внутри класса обращается к одному или нескольким свойствам (экземплярным переменным).Метрика LCOM показывает, насколько методы не связаны друг с другом через свойства .Введём обозначения:
- НЕ СВЯЗАНЫ- количество пар методов без общих экземплярных переменных;
- СВЯЗАНЫ- количество пар методов с общими экземплярными переменными.
- Ij-набор экземплярных переменных, используемых методом Mj.
Очевидно, что НЕ СВЯЗАНЫ=card{Iy|Ii∩Ij=0},
СВЯЗАНЫ=card{Iy|Ii∩Ij≠0}.
Тогда формула для вычисления недостатка связности методах примет вид
LCOM={ НЕ СВЯЗАНЫ - СВЯЗАНЫ, если (НЕ СВЯЗАНЫ>СВЯЗАНЫ)
0 в противном случае.
Можно определить метрику по-другому: LCOM - это количество пар методов, не связанных по свойствам класса, минус количество пар методов, имеющих такую связь.
Рассмотрим примеры применения метрики LCOM.
Пример 1:В классе имеются методы:М1,М2,М3,М4.Каждый метод работает со своим набором экземплярных переменных:
I1={a,b}; I2={a,c}; I3={x,y}; I4={m,n}.
В этом случае
НЕ СВЯЗАНЫ=card(I13, I14,I23,I24,I34,)=5; СВЯЗАНЫ=card(I12)=1.
LCOM=5-1=4
Пример 2:Вклассе используются методы:М1,М2,М3.
Для каждого метода задан свой набор экземплярных переменных:
I1={a,b}; I2={a,c}; I3={x,y},
НЕ СВЯЗАНЫ=card(I13,I23)=2; СВЯЗАНЫ=card(I12)=1
LCOM=2-1=1
Cвязность методов внутри класса должна быть высокой, так как это содействует инкапсуляции. Если LCOM имеет высокое значение, то методы слабо связаны друг с другом через свойства. Это увеличивает сложность, в связи с чем возрастает вероятность ошибок при проектировании. Высокие значения LCOM означают, что класс. вероятно, надо спроектировать лучше (разбиение на 2 или более отдельных класса).Любое вычисление LCOM помогает определить недостатки в проектировании классов, так как эта метрика характеризует качество упаковки данных и методов в оболочку класса. Вывод: связность в классе желательно сохранять высокой, то есть стоит добиваться низкого значения LCOM.
Поскольку основу логического представления ПО образует структура классов, для оценки ее качества удобно использовать метрики Чидамбера-Кемерера.
Набор метрик Чидамбера – Кемерера - одна из пионерских работ по комплексной оценке качества О-О-проектирование. В настоящее время известны многочисленные предложения по усовершенствованию, развитию данного набора.
Контрольные вопросы
|