CERT C: Rule EXP30-C

Не зависите от порядка оценки побочных эффектов

Описание

Определение правила

Не зависите от порядка оценки побочных эффектов.[1]

Реализация Polyspace

Эта проверка значения выражения зависит от порядка оценки или побочных эффектов.

Примеры

расширить все

Проблема

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

Выражение может иметь различные значения при следующих условиях:

  • Одна и та же переменная изменяется более одного раза в выражении или одновременно читается и записывается.

  • Выражение допускает более одного порядка оценки.

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

Риск

Если выражение приводит к различным значениям в зависимости от порядка оценки, его значение становится определенным реализацией.

Пример - Переменная, измененная более одного раза в выражении
int a[10], b[10];
#define COPY_ELEMENT(index) (a[(index)]=b[(index)])/* Noncompliant  */

void main () {
    int i=0, k=0;

    COPY_ELEMENT (k);         /* Compliant */
    COPY_ELEMENT (i++);       
}

В этом примере правило нарушается оператором COPY_ELEMENT(i++) потому что i++ происходит дважды, и порядок вычисления двух выражений не задан.

Пример - Переменная, измененная и используемая в нескольких аргументах функции
void f (unsigned int param1, unsigned int param2) {}

void main () {
    unsigned int i=0;
    f ( i++, i );                 /* Non-compliant */ 
}

В этом примере правило нарушается, потому что не задано, i++ ли операция происходит до или после передачи второго аргумента в f. Вызов f(i++,i) может переводиться в любой из f(0,0) или f(0,1).

Проверяйте информацию

Группа: Правило 03. Выражения (EXP)
Введенный в R2019a

[1] Это программное обеспечение было создано MathWorks, включающее фрагменты: «Сайт SEI CERT-C», © 2017 Университет Карнеги Меллон, Веб-сайт SEI CERT-C + + © 2017 Университет Карнеги Меллон, "Стандарт кодирования SEI CERT C - Правила разработки безопасных, Надежные и безопасные системы - 2016 Edition ", © 2016 Университет Карнеги Меллон, и "Стандарт кодирования SEI CERT C++ - Правила разработки безопасных, Надежные и безопасные системы в C++ - 2016 Edition "© 2016 Университет Карнеги Меллон, с специального разрешения от его Института программной инженерии.

ЛЮБОЙ МАТЕРИАЛ УНИВЕРСИТЕТА КАРНЕГИ МЕЛЛОН И/ИЛИ ЕГО ИНЖЕНЕРНОГО ИНСТИТУТА ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ, СОДЕРЖАЩИЙСЯ В НАСТОЯЩЕМ ДОКУМЕНТЕ, ПОСТАВЛЯЕТСЯ НА БАЗИСЕ «КАК ЕСТЬ». УНИВЕРСИТЕТ КАРНЕГИ МЕЛЛОН НЕ ДАЕТ НИКАКИХ ГАРАНТИЙ, ВЫРАЖЕННЫХ ИЛИ ПОДРАЗУМЕВАЕМЫХ, В ОТНОШЕНИИ ЛЮБОГО ВОПРОСА, ВКЛЮЧАЯ, НО НЕ ОГРАНИЧИВАЯСЬ, ГАРАНТИЮ ПРИГОДНОСТИ ДЛЯ ЦЕЛЕЙ ИЛИ КОММЕРЧЕСКОЙ ВЫГОДЫ, ИСКЛЮЧИТЕЛЬНОСТИ, ИЛИ УНИВЕРСИТЕТ КАРНЕГИ МЕЛЛОН НЕ ДАЕТ НИКАКИХ ГАРАНТИЙ В ОТНОШЕНИИ СВОБОДЫ ОТ ПАТЕНТА, ТОВАРНОГО ЗНАКА ИЛИ НАРУШЕНИЯ АВТОРСКИХ ПРАВ.

Это программное обеспечение и связанная с ним документация не были рассмотрены и не одобрены Университетом Карнеги-Меллон или его Институтом программной инженерии.