exponenta event banner

CERT C: 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 Университет Карнеги-Меллон, со специальным разрешением от его Института программного обеспечения.

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

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