MISRA C:2012 Rule 11.1

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

Описание

Примечание

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

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

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

Объяснение

Правило запрещает следующие два преобразования:

  • Преобразование от указателя функции до любого другого типа. Это преобразование вызывает неопределенное поведение.

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

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

Реализация Polyspace

Polyspace® рассматривает и явные и неявные броски при проверке этого правила. Однако броски от NULL или (void*)0 не нарушайте это правило.

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

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

Примеры

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

typedef void (*fp16) (short n);
typedef void (*fp32) (int n);

#include <stdlib.h>                     /* To obtain macro  NULL */

void func(void) {   /* Exception 1 - Can convert a null pointer 
                     * constant into a pointer to a function */
  fp16 fp1 = NULL;                 /* Compliant - exception  */
  fp16 fp2 = (fp16) fp1;           /* Compliant */
  fp32 fp3 = (fp32) fp1;           /* Non-compliant */
  if (fp2 != NULL) {}              /* Compliant - exception  */
  fp16 fp4 = (fp16) 0x8000;        /* Non-compliant - integer to 
                                    * function pointer */}

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

  • Указатель fp1 из типа fp16 бросок должен ввести fp32. Указатель функции вводит fp16 и fp32 имейте различные типы аргумента.

  • Целое число брошено, чтобы ввести fp16.

Правило не нарушено когда указатели функции fp1 и fp2 брошены к NULL.

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

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

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

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

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

Введенный в R2014b