若定义一个二维数组 array[2][3],则下列表达式所表达的含义是:
array–数组的指针,指向二维数组第一行数据所在的首地址;
array+1–数组的指针,指向二维数组第二行数据所在的首地址;
*array–数据指针,指向二维数组第一行第一列数据的地址;
*array+1–数据指针,指向二维数组第一行第二列数据的地址;
(array+1)–数据指针,指向二维数组第二行第一列数据的地址;
array[1]–数据指针,指向二维数组第二行第一列数据的地址,array[1]==(array+1);
array[1][1]–变量,存放数组第二行第二列的数据;
若定义一个一维数组 array[5],则下列表达式所表达的含义是:
array–数据指针,指向一维数组第一个数据所在的地址;
array+1–数据指针,指向一维数组第二个数据所在的地址;
*array–指针取值,提取一维数组的第一个数据;
*array+1–指针取值求和,一维数组第一个数据的值加上1;
*(array+1)–指针取值,提取一维数组第二个数据;
指针数组:一个数组,里面存放的都是指针,
例如 int (*p)[3]=array; (*p)[3]是一个指针数组,
将array赋给数组指针即将array的第一行赋给指针数组,(*p)[3]可代替array用于数组寻址
#include <stdio.h>
话不多说,上代码!
int main()
{
int array[2][3];
int (*p)[3]=array;
int array1[5]={0,10,2,3,4};
int i,j,k;
for ( i = 0; i < 2; i++)
{
for ( j = 0; j < 3; j++)
{
array[i][j]=k++;
}
}
printf("array指向的地址为%p\n",array);
printf("array+1 指向的地址为%p\n",array+1);
printf("*array指向的地址为%p\n",*array);
printf("*array+1 指向的地址为%p\n",*array+1);
printf("*(array+1) 指向的地址为%p\n",*(array+1));
printf("array[1]指向的地址为%p\n",array[1]);
printf("array[1][1]指向的地址为%p\n\n",&(array[1][1]));
printf("array1指针指向的地址为%p\n",array1);
printf("(array1+1)指针指向的地址为%p\n",array1+1);
printf("array1指针本身存放在计算机中的地为%d\n",&array1);
printf("array1指针指向地址所存放的值为%d\n",*array1);
printf("array1指针指向地址所存放的值加上1的为%d\n",*array1+1);
printf("(array1+1)指针指向地址所存放的值为为%d\n\n",*(array1+1));
printf("array指针指向的地址为:%p,p指针指向的地址
为:%p\n",array,p);
printf("array+1指针指向的地址为:%p,p+1指针指向的地址
为:%p\n",array+1,p+1);
return 0
}
代码运行结果为: