MISRA C:2012 Rule 21.3

Функции выделения памяти и освобождения <stdlib.h> не буду использоваться

Описание

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

Функции выделения памяти и освобождения <stdlib.h> не буду использоваться.

Объяснение

Используя выделение памяти и освобождение стандартные программы могут вызвать неопределенное поведение. Например:

  • Вы освобождаете память это, вы не выделили динамически.

  • Вы используете указатель, который указывает на освобожденное память местоположение.

Реализация Polyspace

Средство проверки отмечает использование calloc, malloc, realloc, aligned_alloc и free функции.

Если вы задаете макросы с теми же именами как эти динамические функции выделения памяти кучи, и вы расширяете макросы в коде, это правило нарушено. Это принято, что правило 21.2 не нарушено.

Дополнительное сообщение в отчете

  • Макрос <имя> не должен использоваться.

  • Идентификатор XX не должен использоваться.

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

Если вы ожидаете нарушение правила, но не видите его, обратитесь к Кодированию Стандартных Нарушений, Не Отображенных.

Примеры

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

#include <stdlib.h>

static int foo(void);

typedef struct struct_1 {
    int a;
    char c;
} S_1;

static int foo(void) {

    S_1 * ad_1;
    int  * ad_2;
    int  * ad_3;

    ad_1 = (S_1*)calloc(100U, sizeof(S_1));        /* Non-compliant */
    ad_2 = malloc(100U * sizeof(int));             /* Non-compliant */
    ad_3 = realloc(ad_3, 60U * sizeof(long));      /* Non-compliant */

    free(ad_1);                                    /* Non-compliant */
    free(ad_2);                                    /* Non-compliant */
    free(ad_3);                                    /* Non-compliant */

    return 1;
}

В этом примере правило нарушено когда функции malloc, calloc, realloc и free используются.

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

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