1.概念
数组指针也就是个指针,用来存放数组的地址。同理,指针数组也就是数组。
int* p,指向整型的指针,可以存放整型的地址
char* pa,指向字符的指针,可以存放字符的地址
数组指针,指向数组的指针,可以存放数组的地址
那么怎样去理解数组的地址呢?
举例1,
int arr[10] = { 0 };
arr- 首元素地址
&arr[0] - 首元素地址
&arr - 数组的地址
int(*p)[10] = &arr;
解析:首先,(*p)说明p 是个指针;然后,int [10] 说明指向数组,数组10个元素,每个元素都是整型。所以,这个p就是数组指针,这时就可以存放数组的地址,即上面存放的是arr数组的地址
举例2,
对比区分一下
int *p1[10];
int (*p2)[10];
//p1,p2分别是什么?
解释:
int p1[10]; //p1先和[]结合,说明p1首先是个数组,类型是int , 是一个存放指针的数组
int (p2)[10]; //p2先和 结合,说明p2首先是个指针,指针指向的数组有10个元素,每个元素都是int的
举例3:
char* arr[5];
怎样取该数组的地址放到指针数组里?
解析:
取数组的地址char* (* parr)[5] = &arr;
parr是指针变量名,* 说明是指针,[5]说明parr指向的数组有5个元素,char* 说明parr指向的数组的元素类型是char *的。
2.练习
打印二维数组
//打印二维数组
#include<stdio.h>
void print1(int arr[3][5], int x, int y)
{
int i, j;
for (i = 0; i < x; i++)
{
for (j = 0; j < y; j++)
printf("%d ",arr[i][j]);
printf("\n");
}
}
void print2(int(*pa)[5], int x, int y)
{
int i, j;
for (i = 0; i < x; i++)
{
for (j = 0; j < y; j++)
{
printf("%d ", *(*(pa + i) + j));
}
printf("\n");
}
}
int main()
{
int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7} };
print1(arr, 3, 5);
printf("\n");
print2(arr, 3, 5);
printf("\n");
return 0;
}
结果:
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7
解释:
print1(arr, 3, 5); arr -数组名,就是首元素的地址,除了两种特殊情况
(&数组名和sizeof(数组名),这两种的数组名是数组的地址,而不是首元素地址)。注意,一维数组的首元素是第一个元素,二维数组的首元素是第一行的元素。