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

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

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

看看执行结果

clip_image002

结论很简单:

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]