MISRA C:2012 Rule 11.7

Бросок не должен выполняться между указателем на объект и типом арифметики нецелого числа

Описание

Примечание

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

Управляйте определением

Бросок не должен выполняться между указателем на объект и типом арифметики нецелого числа.

Объяснение

Это правило касается типов, которые являются по существу Boolean, символом, перечислением или плаванием.

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

  • Броски к или от указателя до типа с плавающей точкой приводят к неопределенному поведению.

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

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

Примеры

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

int foo(void) {

    short *p;
    float  f;
    long  *l;

    f = (float)   p;              /* Non-compliant */
    p = (short *) f;              /* Non-compliant */

    l = (long *)  p;              /* Compliant */
}

В этом примере правило нарушено когда:

  • Указатель p брошен к float.

  • float переменная брошена к указателю на short.

Кастинг между указателем и non-integerer переменной силой вызывает отказ компиляции. Polyspace® отмечает такие броски.

Правило не нарушено когда указатель p брошен к long*.

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

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

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

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

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

Введенный в R2014b