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