Сложность дерева вызовов файла больше заданного порога
Сложность дерева вызовов файла представляет сложность между различными уровнями его дерева вызовов функций. Polyspace® вычисляет сложность дерева вызовов файла как:
Call tree Complexity = number of call occurrences – number of function definitions + 1 | (1) |
Estimated Function Coupling
Polyspace использует порог 20 по умолчанию, если вы не задаете порог. Чтобы задать файл выбора, в котором можно задать порог, используйте Set checkers by file (-checkers-selection-file)
. Также см. «Уменьшение сложности программного обеспечения при помощи Polyspace Checkers».
Когда вы импортируете комментарии из предыдущих анализов при помощи polyspace-comments-import
Polyspace копирует любую рецензирующую информацию о метрике кода Estimated Function Coupling
в предыдущем результате этой проверки в текущем результате. Если текущий результат содержит ту же метрику кода, информация проверки также копируется в метрику кода.
Нарушение этой проверки может указать, что:
Взаимозависимость функций в файле недопустимо высока.
Изменения в одной функции в файле могут ввести ошибки или неожиданное поведение в других функциях файла.
Повторное использование одной функции файла может оказаться трудным из-за взаимозависимости с другими функциями.
Эти факторы затрудняют обслуживание, тестирование и отладку файла.
Чтобы исправить эту проверку, либо измените код, либо измените порог проверки. При рефакторинге кода спроектируйте функции в вашем коде так, чтобы:
Каждая функция выполняет одну конкретную задачу.
Функции имеют минимальные побочные эффекты на другие функции.
Лучшая практика состоит в том, чтобы проверить сложность модуля на ранних стадиях разработки, чтобы избежать дорогостоящего рефакторинга после разработки.
Группа: Комплексность программного обеспечения |
Язык: C | C++ |
Акроним:
SC03
|
Порог по умолчанию: 20 |