二维数组、行指针、指针数组、二级指针
看到这个标题是不是很头大,那么来看段简单的程序:
/*************************************
* 文件名称:pointer.c
* 文件描述:测试二维数组,指针数组,行指针
与二级指针
* 文件作者:by Wang.J,in 2013.11.07
* 文件版本:1.0
* 修改记录:
**************************************/
#include <stdio.h>
int
main(void)
{
int i = 0, j = 0;
int a[4][3] = {{0,1,2}, {3,4,5}, {6,7,8}, {9,10,11}};
int *pa[4]; //指针数组, 数据类型 *变量名[n]
int **pp; //二级指针, 数据类型 **变量名
int (*p)[3]; //行指针, 数据类型 (*变量名)[n]
pa[0] = a[0];
pa[1] = a[1];
pa[2] = a[2];
pa[3] = a[3];
pp = pa;
p = a;
printf("a[4][3]:\n");
for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
printf("%d\t", a[i][j]);
}
printf("\n");
}
printf("\n\n");
printf("*pa[4]:\n");
for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
printf("%d\t", *(pa[i]+j));
}
printf("\n");
}
printf("\n\n");
printf("**pp:\n");
for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
printf("%d\t", *((*pp+i*3)+j));
/*
* 上面的3是(sizeof(a)/sizeof(a[0]))的结果,我嫌太长直接写了3,各位注意!
* 也可以可以使用*(pp[i]+j)的形式,不过上面的形式更好理解一点
*/
}
printf("\n");
}
printf("\n\n");
printf("(*p)[3]:\n");
for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
printf("%d\t", *(*(p+i)+j));
}
printf("\n");
}
printf("\n\n");
return 0;
}
看看执行结果
结论很简单:
a[i][j] == pp[i][j] == *(*(pp+i)+j) == *(pa[i]+j) == *(*(p+i)+j)
还有一个结论:
*(p+i) = p[i];大家可以使用这个结论简化上面的式子.
a[i][j] == pp[i][j] == pa[i][j] == p[i][j]