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