这几句代码啥意思,谁理解的解释下

  int c[] =
    {
        {
            1,2,3,4
        }
    };
    int (*d)[4] = c;
    int x = d; 
    int y = *d;
    int z = **d;
    int w = *(*d);

x赋值表示明白了,结果y赋值就懵逼了,然后就一直懵逼下去,谁理解了的,麻烦解释下

可参考以下解释:

    int (*d)[4] = c;    // 一个指向有4个整型数数组的指针,保存了数组c的地址
    int x = d;          // d是指针d保存的地址(数组c的地址)
    int y = *d;         // *d是去指针d地址里取出保存的地址(数组c的地址)
    int z = **d;        // **d是取到数组c的地址后,再去c的地址里取值
    int w = *(*d);      // *(*d)是取到数组c的地址后,再去c的地址里取值

int (*d)[4] = c,也就是说(*d)=c ,d=&c(c是数组首地址,d指向c的地址,d相当于一个二级指针,或者二维数组的首地址)
x=d,把这个地址转成int赋值给x
y=*d, *d就是c的地址,也就是把c的地址转成int类型赋值给y
z=**d , 就是取c[0]的值赋值给z
w=*(*d) ,跟z的值是一样的


这种写法看看就行了,在编译器里这么写会报错的

int ( * d)[4] = c; ---- 这里定义的d是一个int * 类型的数组。也就是每个数组成员都是int *,这里将已定义的c数组地址作为d数组的第一个成员
int x = d; ------ 将x赋值为d数组的首地址
int y = * d; ----- * d就是d数组的第一个成员值,根据上面的定义,就是c数组,所以y就赋值为c数组的首地址。由于d数组的第一个成员就是c数组,所以x和y的值是相同的,都是c数组地址
int z = ** d; ----这是取得数组d的第一个成员c数组的第一个元素值。实际d相当于一个二维数组,因此这里相当于z = d[0][0],z的值就是1
int w = * ( * d); ---这个和z的写法是一样的,值也是1

单步对应汇编指令