Количество отдельных вызовов функций в теле функции больше заданного порога
Этот дефект возникает на функции, когда количество вызовов отдельных функций в его теле больше, чем заданный порог проверки. Для получения дополнительной информации о том, как Polyspace вычисляет количество вызываемых функций, смотрите Number of Called Functions
.
Polyspace® использует порог по умолчанию 7, если вы не задаете порог. Чтобы задать файл выбора, в котором можно задать порог, используйте Set checkers by file (-checkers-selection-file)
. Также см. «Уменьшение сложности программного обеспечения при помощи Polyspace Checkers».
Когда вы импортируете комментарии из предыдущих анализов при помощи polyspace-comments-import
Polyspace копирует любую рецензирующую информацию о метрике кода Number of Called Functions
в предыдущем результате этой проверки в текущем результате. Если текущий результат содержит ту же метрику кода, информация проверки также копируется в метрику кода.
Нарушение этой проверки может указать, что:
Функция зависит от многих функций, и изменения в любой из этих функций могут привести к неожиданному поведению.
Функция выполняет слишком много задач.
Модуль может содержать неожиданную или незапланированную разработку.
Эти факторы затрудняют обслуживание и отладку модуля.
Чтобы исправить эту проверку, либо измените код, либо измените порог проверки. При рефакторинге кода спроектируйте функции в вашем коде так, чтобы:
Каждая функция выполняет одну конкретную задачу.
Функции имеют минимальные побочные эффекты на другие функции.
Лучшая практика состоит в том, чтобы проверить сложность модуля на ранних стадиях разработки, чтобы избежать дорогостоящего рефакторинга после разработки.
Группа: Комплексность программного обеспечения |
Язык: C | C++ |
Акроним:
SC05
|
Порог по умолчанию: 7 |