1.什么是数组指针
在介绍数组指针之前,首先要区分数组指针和指针数组的区别。这是初学者很容易搞混的。
(1)指针数组
指针数组,顾名思义就是存放指针的数组。我们可以定义一个数组来存放整型、字符型的变量,当然也可以用数组来存放指针。
int arr[10]; //存放整型
char arr[10]; //存放字符
int* arr[10]; //存放指针
举一个例子来说明。
现在给出二维数组 arr[3][3] = { {1,2,3} , {3,4,5} , {6,7,8} },要求用指针数组的形式打印出来。对于二维数组,我们可以把它的每一行看成一个一维数组,然后再用一个数组来存放这些一维数组的地址(指针)。由于数组中元素是连续存放的,所以我们就可以把这个二维数组打印出来。
int main()
{
int arr1[3] = { 1,2,3 };
int arr2[3] = { 4,5,6 };
int arr3[3] = { 7,8,9 };
int* pa[3] = { arr1,arr2,arr3 };
int i,j;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 3; j++)
{
printf("%d ", *(*(pa+i)+j));
}
printf("\n");
}
return 0;
}
(2)数组指针
与指针数组不同,指针数组归根结底还是一个数组。但是数组指针是一个指针变量,它指向一个数组(存放这个数组的地址)。
int arr1[10] = { 0 };
int(*p)[10] = &arr1;
由于[ ]的优先级是高于*的,所以在定义数组指针时我们要将*和指针名用括号括起来,保证它们先结合。
我们也可以这样理解,用括号括起来的*p表示p是一个指针变量。这个变量指向的是int型的数组,并且这个数组有10个元素。