Связность (программирование)



Связность, или прочность (англ. cohesion, module strength), — мера силы взаимосвязанности элементов внутри модуля; способ и степень, в которой задачи, выполняемые некоторым программным модулем, связаны друг с другом.

Макконнелл объясняет понятие связности на примере класса (как частного случая модуля): «связность характеризует то, насколько хорошо все методы класса или все фрагменты метода соответствуют главной цели, — иначе говоря, насколько сфокусирован класс».

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

Типы связности

В стандарте ISO/IEC/IEEE 24765 и современной литературе предлагается рассматривать следующие типы связности:

  • случайная (англ. coincidental);
  • коммуникационная (англ. communicational);
  • функциональная (англ. functional);
  • логическая (англ. logical);
  • процедурная (англ. procedural);
  • последовательностная (англ. sequential) и
  • временная (англ. temporal).
Случайная связность Тип связности, при котором задачи, выполняемые программным модулем, не имеют функциональной взаимосвязи друг с другом. Коммуникационная связность Тип связности, при котором задачи, выполняемые программным модулем, используют одни и те же входные данные или участвуют в формировании одних и тех же выходных данных. Функциональная связность Тип связности, при котором все задачи, выполняемые программным модулем, вносят вклад в выполнение одной и той же функции. Логическая связность Тип связности, при котором задачи, выполняемые программным модулем, реализуют логически сходные функции (например, одинаково обрабатывают разные типы входных данных). Процедурная связность Тип связности, при котором все задачи, выполняемые программным модулем, участвуют в некоторой программной процедуре. Последовательностная связность Тип связности, при котором выходные данные одной задачи, выполняемой программным модулем, служат входным данными для другой задачи, выполняемой этим же модулем. Временная связность Тип связности, при котором все задачи, выполняемые программным модулем, требуются для некоторой фазы выполнения программы (например, модуль содержит все задачи для инициализации).

Эти виды связности аналогичны используемым семи видам связности в SADT.