Рассмотрите и зафиксируйте проверки переполнения

Выполните один или несколько из этих шагов, пока вы не определите фиксацию для проверки Overflow. Существует несколько способов зафиксировать проверку. Для описания проверки и примеров кода, смотрите Overflow.

Иногда, особенно для оранжевой проверки, можно решить, что проверка не представляет действительную ошибку, но предположение Polyspace®, которое не верно для кода. Если можно использовать опцию анализа, чтобы ослабить предположение, повторно выполнить верификацию с помощью той опции. В противном случае можно добавить комментарий и выравнивание в результате или коде.

Для общего рабочего процесса, который применяется ко всем проверкам, смотрите, Интерпретируют Результаты Программы автоматического доказательства Кода в Пользовательском интерфейсе Рабочего стола Polyspace.

Шаг 1: интерпретируйте информацию о проверке

Установите свой курсор на операцию, которая переполняется.

Получите следующую информацию из подсказки:

  • Переменная операнда можно ограничить, чтобы избежать переполнения.

    В предыдущем примере, левом операнде, val, имеет полный спектр значений.

    Возможная фиксация: Чтобы избежать переполнения, выполните умножение только если val находится в определенной области значений.

    if(val < INT_MAX/2)
        return(val*2);
    else 
        /* Alternate action */
  • Вероятная первопричина для переполнения, если обозначено в подсказке.

    В предыдущем примере программное обеспечение идентифицирует заблокированную функцию, getVal, как вероятная причина.

    Возможная фиксация: Чтобы избежать переполнения, ограничьте возвращаемое значение getVal. Например, задайте тот getVal возвращает значения в определенной области значений, например, 1..10. Для получения дополнительной информации смотрите Предположения О Заблокированных Функциях.

Шаг 2: определите первопричину проверки

Проследите поток данных, начинающий с переменной операнда, которую вы хотите ограничить. Идентифицируйте подходящую точку, чтобы задать ваше ограничение.

В следующем примере проследите поток данных, начинающий с tempVal.

val = func();
.
.
tempVal = val;
.
.
tempVal++ ;
В этом примере вы можете найти что:

  1. tempVal получает полный диапазон значений от val.

    Возможная фиксация: Присвойте val к tempVal только если val меньше определенного значения.

  2. val получает полный диапазон значений от func.

    Возможная фиксация: Ограничьте возвращаемое значение func, любой в теле func или через интерфейс Polyspace Constraint Specification, если func заблокирован. Для получения дополнительной информации смотрите Предположения О Заблокированных Функциях.

Чтобы проследить поток данных, выберите проверку и отметьте информацию о панели Result Details.

  • Если панель Result Details показывает последовательность инструкций, которые приводят к проверке, выбирают каждую инструкцию.

  • Если панель Result Details показывает номер строки вероятной причины для проверки, щелкните правой кнопкой по панели Source. Выберите Go To Line.

  • В противном случае:

    1. Найдите предыдущую операцию записи на переменной операнда.

      Пример: предыдущая операция записи на tempVal tempVal=val.

    2. При предыдущей операции записи идентифицируйте новую переменную, чтобы проследить.

      Установите свой курсор на переменные, вовлеченные в операцию записи, чтобы видеть их значения. Значения помогают вам решить который переменная проследить.

      Пример: в tempVal=val, вы находите тот val имеет полный диапазон значений. Поэтому вы прослеживаете val.

    3. Найдите предыдущую операцию записи на новой переменной. Продолжите прослеживать таким образом, пока вы не идентифицируете точку, чтобы задать ваше ограничение.

      Пример: предыдущая операция записи на val val=func(). Можно принять решение задать ограничение на возвращаемое значение func.

В зависимости от переменной используйте следующие ярлыки навигации, чтобы найти предыдущие экземпляры. Можно выполнить следующие шаги в пользовательском интерфейсе Polyspace только.

ПеременнаяКак найти предыдущие экземпляры переменной

Локальная переменная

Используйте один из следующих методов:

  • Ищите переменную.

    1. Щелкните правой кнопкой по переменной. Выберите Search For All References.

      Все экземпляры переменной появляются на панели Search с текущим подсвеченным экземпляром.

    2. На панели Search выберите предыдущие экземпляры.

  • Просмотрите исходный код.

    1. Дважды кликните переменную на панели Source.

      Все экземпляры переменной подсвечены.

    2. Прокрутите, чтобы найти предыдущие экземпляры.

Глобальная переменная

Щелкните правой кнопкой по переменной. Если опция, Show In Variable Access View появляется, переменная, является глобальной переменной.

  1. Выберите опцию Show In Variable Access View.

    На панели Variable Access показывают текущий экземпляр переменной.

  2. На этой панели выберите предыдущие экземпляры переменной.

    Операции записи на переменной обозначаются с и операции чтения с.

Функциональное возвращаемое значение

ret=func();

  1. Найдите функциональное определение.

    Щелкните правой кнопкой по func на панели Source. Выберите Go To Definition, если опция существует. Если определение не доступно для Polyspace, выбирание опции берет вас к объявлению функции.

  2. В определении func, идентифицируйте каждый return оператор. Переменная, которую возвращает функция, является вашей новой переменной, чтобы проследить.

Можно также определить, связаны ли переменные в какой-либо операции от некоторой предыдущей операции. Смотрите Находят Отношения Между Переменными в Коде.

Совет

Чтобы различать целое число и переполнение плавающее, используйте столбец Detail на панели Results List. Кликните по заголовку столбца так, чтобы целое число и переполнение плавающее группировались. Если вы не видите столбец Detail, щелкните правой кнопкой по любому другому заголовку столбца и включите этот столбец.

Шаг 3: ищите частые причины проверки

Если операция, вызывающая переполнение, происходит в цикле или в теле рекурсивной функции:

  • Смотрите, можно ли сократить количество запусков цикла или рекурсий.

  • Смотрите, можно ли поместить выходное условие в цикл или рекурсивную функцию перед переполнением операции.

Шаг 4: проследите проверку до предположения Polyspace

Смотрите, можно ли проследить оранжевую проверку до предположения Polyspace, которое происходит ранее в коде. Если предположение не сохраняется в вашем случае, добавьте комментарий или выравнивание в вашем результате или коде. Смотрите Результаты Polyspace Адреса Через Исправления ошибок или Выравнивания.

Например, вы используете энергозависимую переменную в своем коде. То:

  1. Polyspace принимает, что энергозависимая переменная является полным диапазоном на каждом шаге в коде.

  2. Операция с помощью той переменной может переполниться и является поэтому оранжевой.

  3. Если вы знаете, что переменная берет меньшую область значений значений, добавьте комментарий и выравнивание в вашем коде, описывающем, почему вы не изменили свой код.

Для получения дополнительной информации смотрите Аналитические Предположения Программы автоматического доказательства Кода.

Примечание

Прежде, чем выровнять по ширине оранжевую проверку, рассмотрите тщательно, можно ли улучшить проект кодирования.