二维数组、行指针、指针数组、二级指针

二维数组、行指针、指针数组、二级指针数组

看到这个标题是否是很头大,那么来看段简单的程序:测试

/************************************* * 文件名称: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; }

看看执行结果spa

clip_image002

结论很简单:.net

a[i][j] == pp[i][j] == *(*(pp+i)+j) == *(pa[i]+j) == *(*(p+i)+j)指针

还有一个结论:code

*(p+i) = p[i];你们可使用这个结论简化上面的式子.blog

a[i][j] == pp[i][j] == pa[i][j] == p[i][j]ip

相关文章
相关标签/搜索