MISRA C:2012 Dir 1.1

Любое заданное реализацией поведение, от которого зависит выход программы, должно быть зарегистрировано и изучено

Описание

Примечание

Используйте Bug Finder вместо Code Prover для проверки правил кодирования. Поддержка кодирования правил, регистрируясь в Code Prover будет удалена в будущем релизе. См. Вопросы совместимости.

Направляющее определение

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

Объяснение

Построение кода задало реализацией поведение, если стандарт C позволяет компиляторам выбирать свои собственные технические требования для построения. Полный список заданного реализацией поведения доступен в Приложении J.3 стандартного ISO/IEC 9899:1999 (C99) и в Приложении G.3 стандартного ISO/IEC 9899:1990 (C90).

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

Реализация Polyspace

Анализ обнаруживает следующие возможности заданного реализацией поведения в C99 и их дубликатов в C90. Если вы знаете поведение своей реализации компилятора, выравниваете по ширине результат анализа с соответствующими комментариями. Чтобы выровнять по ширине результат, присвойте одно из этих состояний: Justified, No action planned, или Not a defect.

Совет

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

Приложение стандарта C99 касательноПоведение, которое будет зарегистрированоКак Polyspace® Помогает
J.3.2: СредаАльтернативный способ, в который main функция может быть задана.

Анализ отмечает main с аргументами и возвращают типы кроме:

int main(void) { ... }
или
int main(int argc, char *argv[]) { ... }

Смотрите раздел 5.1.2.2.1 из Стандарта C99.

J.3.2: СредаНабор имен среды и метода для изменения списка сред используется getenv функция.

Анализ отмечает использование getenv функция. Для этой функции необходимо знать список переменных окружения и как список изменяется.

Смотрите раздел 7.20.4.5 из Стандарта C99.

J.3.6: плавающая точкаОкругляющиеся поведения охарактеризованы нестандартными значениями FLT_ROUNDS.

Анализ отмечает включать float.h если значения FLT_ROUNDS находятся вне набора, {-1, 0, 1, 2, 3}. Только значения в этом наборе приводят к четко определенному поведению округления.

Смотрите раздел 5.2.4.2.2 из Стандарта C99.

J.3.6: плавающая точкаМетоды оценки охарактеризованы нестандартными отрицательными величинами FLT_EVAL_METHOD.

Анализ отмечает включать float.h если значения FLT_EVAL_METHOD находятся вне набора, {-1, 0, 1, 2}. Только значения в этом наборе приводят к четко определенному поведению для операций с плавающей точкой.

Смотрите раздел 5.2.4.2.2 из Стандарта C99.

J.3.6: плавающая точкаНаправление округления, когда целое число преобразовано в число с плавающей запятой, которое не может точно представлять исходное значение.

Анализ отмечает преобразования от целого числа до типов данных с плавающей точкой меньшего размера (например, 64-битный int к 32-битному float).

Смотрите раздел 6.3.1.4 из Стандарта C99.

J.3.6: плавающая точкаНаправление округления, когда число с плавающей запятой преобразовано в более узкое число с плавающей запятой.

Анализ отмечает эти преобразования:

  • double к float

  • long double к double или float

Смотрите раздел 6.3.1.5 из Стандарта C99.

J.3.6: плавающая точкаСостояние по умолчанию для FENV_ACCESS прагма.

Анализ отмечает использование прагмы кроме:

#pragma STDC FENV_ACCESS ON
или
#pragma STDC FENV_ACCESS OFF

Смотрите раздел 7.6.1 из Стандарта C99.

J.3.6: плавающая точкаСостояние по умолчанию для FP_CONTRACT прагма.

Анализ отмечает использование прагмы кроме:

#pragma STDC FP_CONTRACT ON
или
#pragma STDC FP_CONTRACT OFF

Смотрите раздел 7.12.2 из Стандарта C99.

J.3.11: предварительная обработка директивПоведение на каждом распознало non-STDC #pragma директива.

Анализ отмечает использование прагмы:

#pragma pp-tokens
где обрабатывающий маркерный STDC сразу не делает followpragma. Например:
#pragma FENV_ACCESS ON

Смотрите раздел 6.10.6 из Стандарта C99.

J.3.12: Библиотечные функцииЛи feraiseexcept функционируйте повышает ''неточное'' исключение с плавающей точкой в дополнение к ''переполнению'', или ''недостаточно заполните'' исключение с плавающей точкой.

Анализ отмечает вызовы feraiseexcept функция.

Смотрите раздел 7.6.2.3 из Стандарта C99.

J.3.12: Библиотечные функцииСтроки кроме "C" и "" это может быть передано в качестве второго аргумента setlocale функция.

Анализ отмечает вызовы setlocale функционируйте, когда его вторым аргументом не будет "C" или "".

Смотрите раздел 7.11.1.1 из Стандарта C99.

J.3.12: Библиотечные функцииТипы заданы для float_t и double_t когда значение FLT_EVAL_METHOD макрос меньше 0 или больше, чем 2.

Анализ отмечает включать math.h если FLT_EVAL_METHOD имеет значения вне набора {0,1,2}.

Смотрите раздел 7.12 из Стандарта C99.

J.3.12: Библиотечные функцииОснова 2 логарифма модуля используется the remquo функции в сокращении частного.

Анализ отмечает вызовы remquo, remquof и remquol функция.

Смотрите раздел 7.12.10.3 из Стандарта C99.

J.3.12: Библиотечные функцииСостояние завершения, возвращенное в серверную среду abortвыход, или _Exit функция.

Анализ отмечает вызовы abortвыход, или _Exit функция.

Смотрите разделы 7.20.4.1, 7.20.4.3 или 7.20.4.4 из Стандарта C99.

Поиск и устранение проблем

Если вы ожидаете нарушение правила, но не видите его, относитесь, чтобы Диагностировать, Почему Кодирующие Стандартные Нарушения Не Появляются как ожидалось.

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

Группа: реализация
Категория: необходимый
Категория AGC: необходимый

Вопросы совместимости

развернуть все

Не рекомендуемый запуск в R2021b

Введенный в R2017b