Распределение Calloc противоречиво - PullRequest
0 голосов
/ 13 апреля 2019

Я создаю двумерный массив целых чисел, используя указатели и функцию calloc.Дело в том, что я выделяю матрицу 3х5.И действительно, есть 3 строки, но 6 столбцов.Я не могу понять это поведение.Кто-то знает, что я делаю не так?

int main() {


int **new_lib = (int **) calloc(3, sizeof(int *));

if (new_lib == NULL) {
    fprintf(stderr, "Error: out of memory (create_library() part 1)\n");
    exit(1);
}

for (int i = 0; i < 3; ++i) {
    new_lib[i] = (int *) calloc(5, sizeof(int));

    if (new_lib[i] == NULL) {

        fprintf(stderr, "Error: out of memory (create_library() part 2)\n");
        exit(1);
    }
}

for (int i = 0; i < 3; ++i) {
    for (int j = 0; j < 6; ++j) {
        new_lib[i][j] = j * (i + 1) + i * (j + 1);
    }

}

for (int i = 0; i < 3; ++i) {
    for (int j = 0; j < 6; ++j) {
        printf("[%i][%i] = %i ", i, j, new_lib[i][j]);
    }
    printf("\n");
}
}

И печать правильна для еще одного столбца:
[0][0] = 0 [0][1] = 1 [0][2] = 2 [0][3] = 3 [0][4] = 4 [0][5] = 5 [1][0] = 1 [1][1] = 4 [1][2] = 7 [1][3] = 10 [1][4] = 13 [1][5] = 16 [2][0] = 2 [2][1] = 7 [2][2] = 12 [2][3] = 17 [2][4] = 22 [2][5] = 27

1 Ответ

2 голосов
/ 13 апреля 2019

Это всегда соответствует. Здесь у вас есть несколько более общих. Для лучшей читабельности кода нет проверок ошибок размещения.

void *allocate(size_t selem, size_t rows, size_t cols)
{
    void **array = calloc(rows, sizeof(void *));

    for(size_t row =0; row < rows; row++)
    {
        array[row] = calloc(cols, selem);
    }
    return array;
}


int main()
{
    int **array = allocate(sizeof(int), 3, 5);

    for(size_t r = 0; r < 3; r++)
    {
        printf("%p\n",array[r]);   
    }

    for(size_t r = 0; r < 3; r++)
    {
        for(size_t c = 0; c < 5; c++)
        {
            array[r][c] = r*10 + c;   
        }
    }
    for(size_t r = 0; r < 3; r++)
    {
        for(size_t c = 0; c < 5; c++)
        {
            printf("%02d ", array[r][c]);   
        }
        printf("\n");
    }
}

https://onlinegdb.com/Hko5Wjy5V

редактировать

Вы можете использовать другие типы. Просто передайте правильный размер и назначьте правильный тип указателя

typedef struct
{
    double  x[1000];
    int y[500]
    /* more stuff */
}MYSTRUCT;

int main()
{
    MYSTRUCT *ptr = allocate(sizeof(MYSTRUCT), 10, 50);
...