是这样的,一个是小甲鱼课程里面的那个,就是有关**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;
}
int **p = &array[0]
int **p = array;
这个应该没问题的,看错误提示,你是之前的array是不是定义成
int array(*)[4]
了
改成
int *array[4];
看看
别人可以你这报错,是因为你们用的是不同编译器或不同编译选项造成的。
这种写法本身就有问题就是错误的,十年老程序员都不敢这么写,别被网上的误导了。
这样构造的二维数组存的时候还是一维的样子,所以不管你怎么对array操作,它都像一个一维数组
array[0]的类型是int[4]
你可以把这个赋给int*p1=array[0];
,然后就可以用p1[0]
索引到p1[12];
但是&array[0]
还是int*[4]
类型,是不能赋给int**p
的
正确的赋值是int**p=&p1
,但是这样赋值后并没有什么作用,因为索引数组的时候不方便
另外我认为课程里面构造的可能是动态的二维数组?