是这样的,一个是小甲鱼课程里面的那个,就是有关**p的问题,他这里这项没问题啊,我如果去理解也是没有问题的,但是我这边就出现了类型不匹配的问题。没有打错。


是这样的,一个是小甲鱼课程里面的那个,就是有关**p的问题,他这里这项没问题啊,我如果去理解也是没有问题的,但是我这边就出现了类型不匹配的问题。没有打错。


#include <stdio.h>
int main()
{
// array是二维数组,它的元素在内存里是线性连续排列的
int array[3][4] = {{0, 1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
{
// array首地址的类型是int (*)[4],表示它是一个指针指向一维数组(int [4])
// array指向的就是第一行数组的首地址(也是二维数组的首地址)
// array+1指向的是第二行数组的首地址
// 依次类推
// 所以,如果你要把array首地址赋值给另一个指针,那么你得用下面的语句定义其指针类型
// 和array的指针类型相同
int(*p)[4] = array;
// 而不能用 int **p = array;
// 因为这里p的类型是int **,它表示p是一个指针指向的是int*类型(即另一个指向整型的指针)
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
printf("%d ", p[i][j]);
printf("\n");
}
}
{
// 另外你也可以直接把二维数组当作线性数组来访问,不过需要直接换算一下二维数组下标到一维数组下标
int *p = &array[0][0];
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
printf("%d ", p[i * 4 + j]);
printf("\n");
}
}
return 0;
}