一. 指针数组
1.本质上是一个数组,写法如下:int *p1[10]
意思是:这是一个数组,数组有10个元素,每个元素都是int 指针,
从语法级别理解:[]的优先级比 *高,那么首先P1和[]结合,也就是p1[10]是个数组,然后才会和*组合。
2.有啥用?C语言的main函数的第二个参数就是一个指针数组,第一个参数是参数个数。
void main(int argc, char *argv[]){
}
二. 数组指针
1.本质上是一个指针,这个指针指向的是数组. int (*p2)[10]
这个指针指向的是一个数组,那么这个数组存储的是啥呢?存储的是int数组,该数组的大小是10
2.有啥用?二维数组的第一维就是一个数组指针,
我们以int[3][8] arr为例分析:这这里,我们为了好理解,将第一维写成 arr[0], arr[1],arr[2]
arr[0]:这个数组有8个元素,每个元素都是int,就是 int (*pint0)[8]
因此当二维数组做形式参数的时候,写法也可以变成如下的样子
//原始的样子
int max1(int arr[3][8] ) {
return 0;
}
int max2(int(*arr)[8]) {
return 0;
}
3.结合 二维数组的其他应用
既然二维数组的第一维就是数组指针,因此我们可以让 一个数组指针 指向 二维数组的任意一个 第一维
int arr[3][8];
int (*p)[8] = arr[0][0];//让该指针指向 二维数组的第一个第一维
int (*p)[8] = arr[1][0];//让该指针指向 二维数组的第二个第一维
int (*p)[8] = arr[2][0];//让该指针指向 二维数组的第三个第一维
int (*p)[8] = arr;//让该指针指向 二维数组的第一个第一维
p++; 应该跳多少呢?p是一个数组指针,指针跳多少,决定于这个指针指向的是啥?
例如:int a ; int *pa = &a; 那么pa++,跳的是4字节
当前 p 指向的是一个数组,这个数组个数是8,每一个数组都是int,因此p指向的大小是 4*8 = 32个字节
验证
printf("%d\n", p);
p++;
printf("after p++ ,%d\n", p);
1655698656
after p++ ,1655698688
void main() {
int arr[3][8] = { {111111,2,3},{6,7,8,9,0},{10,20} };
int(*p)[8] = &arr[0][0]; // 让该指针指向 二维数组的第一个第一维
printf("%d\n",**p);//p是一个数组指针,首先是个指针,这个指针指向一个数组,因此在解析的时候,*p代表了从指针的指向解析出来第一个:是一个数组。那么还要解析出来数组的第几个,还需要一个*
//解析arr第一维的第一个数组
printf("解析arr第一维的第一个数组\n");
for (int i = 0; i < 8;i++) {
printf("%d\n", *(*p + i));
}
printf("解析arr的全部数据\n");
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 8; j++) {
printf("%d\n", *(*(p + i) + j));
}
}
printf("%d\n", p);
p++;
printf("after p++ ,%d\n", p);
printf("断点在这里");
}