Переполнение из операции между плавающими точками
Этот дефект возникает, когда использование с переменных с плавающей точкой мможетпривести к значениям, которые не могут быть представлены типом данных результата. Тип данных переменной определяет количество байтов, выделенных для переменного хранилища, и ограничивает область значений допустимых значений.
Точное выделение ресурсов хранения для различных типов с плавающей точкой зависит от процессора. См. Target processor type (-target)
.
Переполнения могут привести к непредсказуемым значениям от расчетов. Результатом может быть бесконечность или максимальное конечное значение в зависимости от режима округления, используемого в реализации. Если вы используете результат переполнения расчетов в последующих расчетах и не учитываете переполнение, можно увидеть неожиданные результаты.
Исправление зависит от первопричины дефекта. Часто детали результата показывают последовательность событий, которые привели к дефекту. Используйте этот список событий, чтобы определить, как переменные в переполненных расчетах получают свои текущие значения. Вы можете реализовать исправление на любом событии в последовательности. Если сведения о результате не отображают историю событий, можно отследить их с помощью опций правого щелчка в исходном коде и просмотреть предыдущие связанные события. Смотрите также Результаты интерпретации Bug Finder в интерфейсе пользователя Polyspace Desktop.
См. примеры исправлений ниже.
Если вы не хотите устранять проблему, например, когда вы обрабатываете бесконечности в коде, добавляйте комментарии к своему результату или коду, чтобы избежать другого рассмотрения. Смотрите Адрес Результаты Polyspace через исправления ошибок или обоснования.
Группа: Численный |
Язык: C | C++ |
По умолчанию: Off |
Синтаксис командной строки: FLOAT_OVFL |
Влияние: Низкое |
ИДЕНТИФИКАТОР CWE: 189, 682, 873 |