C 3d массив динамического распределения памяти, вопрос, нужна помощь

Я искал в Интернете способ динамического выделения пространства для 3D-матрицы, скажем, типа int. И я нашел много сайтов, посвященных двумерным матрицам, и этот http://www.taranets.com/cgi/ts/1.37/ts.ws.pl?w=329;b=286 И был такой пример, как показано ниже. Я понял все приведенные выше примеры, но вот что касается 3D, я не могу. Создатель выделяет пространство в обратном порядке или что-то еще? Он начинает с выделения места под всю матрицу, а потом переходит к оси Z? Вот чего я не могу понять.

Кроме того, если вы знаете какие-либо хорошие сайты, посвященные этому, разместите их здесь, это будет оценено.

    /* Program 9.4 from PTRTUT10.HTM   6/13/97 */
// http://www.taranets.com/cgi/ts/1.37/ts.ws.pl?w=329;b=286

#include <stdio.h>
#include <stdlib.h>
#include <stddef.h>

int X_DIM=16;
int Y_DIM=5;
int Z_DIM=3;

int main(void)
{
    char *space;
    char ***Arr3D;
    int y, z;
    ptrdiff_t diff;

    /* first we set aside space for the array itself */

    space = malloc(X_DIM * Y_DIM * Z_DIM * sizeof(char));

    /* next we allocate space of an array of pointers, each
       to eventually point to the first element of a
       2 dimensional array of pointers to pointers */

    Arr3D = malloc(Z_DIM * sizeof(char **));

    /* and for each of these we assign a pointer to a newly
       allocated array of pointers to a row */

    for (z = 0; z < Z_DIM; z++)
    {
        Arr3D[z] = malloc(Y_DIM * sizeof(char *));

        /* and for each space in this array we put a pointer to
           the first element of each row in the array space
           originally allocated */

        for (y = 0; y < Y_DIM; y++)
        {
            Arr3D[z][y] = space + (z*(X_DIM * Y_DIM) + y*X_DIM);
        }
    }

    /* And, now we check each address in our 3D array to see if
       the indexing of the Arr3d pointer leads through in a
       continuous manner */

    for (z = 0; z < Z_DIM; z++)
    {
        printf("Location of array %d is %p\n", z, *Arr3D[z]);
        for ( y = 0; y < Y_DIM; y++)
        {
            printf("  Array %d and Row %d starts at %p\n", z, y, Arr3D[z][y]);
            diff = Arr3D[z][y] - space;
            printf("    diff = %d  ",diff);
            printf(" z = %d  y = %d", z, y);
        }
        putchar('\n');
    }
    putchar('\n');
    system("PAUSE");
    return 0;
}

person Martin Berger    schedule 03.02.2010    source источник


Ответы (2)


пространство действительно является памятью, выделенной для всей матрицы.

Однако он продолжает создавать указатели на области, расположенные в пространстве с помощью

Arr3D = malloc(Z_DIM * sizeof(char **));

Назначение Arr3D — просто способ доступа к пространству посредством индексации (с указанием индексов Z, Y, X). Пространство имеет только один индекс, поэтому, если вы хотите получить доступ к матричному элементу [a][b][c] через пробел, вам нужно будет преобразовать его в один space[d], где d — что-то вроде a*Y_DIM*Z_DIM + b*Z_DIM+c. Так что с Arr3D вы можете получить доступ от [a][b][c] до Arr3D[a][b][c].

Arr3D сам по себе является массивом char**, которые являются указателями на указатели типа char. Arr3D[z] является указателем на массив указателей на символы. Затем каждый Arr3D[z][y] указывает на определенную строку в исходной матрице 3x3 с

Arr3D[z][y] = space + (z*(X_DIM * Y_DIM) + y*X_DIM);

Итак, с помощью Arr[1][2] вы получаете доступ к строке с z=1, y=2 матрицы.

person Will    schedule 03.02.2010
comment
Верно. Основная концепция здесь заключается в том, что space указывает на фактический 3D-массив, сглаженный в 1D-массив, а Arr3D настраивается как индекс в этом массиве — это просто делает доступ к нему более удобным. - person caf; 04.02.2010
comment
Теперь это немного яснее, я понимаю, как это работает, но у меня все еще есть проблемы с визуализацией доступа к перевернутому трехмерному массиву с помощью ZYX. Этот пример больше подходит для меня прямо сейчас: Трехмерные массивы"> stackoverflow.com/questions/1824363/. Имеет больше смысла для новичка, как я. Спасибо Уиллу и другим за помощь! - person Martin Berger; 04.02.2010

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

person Liz Albin    schedule 03.02.2010