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