zoukankan      html  css  js  c++  java
  • 二维数组、行指针、指针数组、二级指针

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

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

    /*************************************
     * 文件名称: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]:
    ");
        for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
            for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
                printf("%d	", a[i][j]);
            }
            printf("
    ");
        }
        printf("
    
    ");
    
        printf("*pa[4]:
    ");
        for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
            for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
                printf("%d	", *(pa[i]+j));
            }
            printf("
    ");
        }
        printf("
    
    ");
    
        printf("**pp:
    ");
        for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
            for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
                printf("%d	", *((*pp+i*3)+j));
                /*
                * 上面的3是(sizeof(a)/sizeof(a[0]))的结果,我嫌太长直接写了3,各位注意!
                * 也可以可以使用*(pp[i]+j)的形式,不过上面的形式更好理解一点
                */
            }
            printf("
    ");
        }
        printf("
    
    ");
    
        printf("(*p)[3]:
    ");
        for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) {
            for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) {
                printf("%d	", *(*(p+i)+j));
            }
            printf("
    ");
        }
        printf("
    
    ");
    
        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]

  • 相关阅读:
    mongoDB看这篇就够了
    放不下
    jmeter连接不上MySQL数据库的原因以及解决方法
    SecureCRT自动断开连接的解决方法
    Linux及Windows查看占用端口的进程
    网络基础知识
    selenium中driver.close()和driver.quit()的不同点
    day2_窗口句柄切换
    day6_异常捕捉
    day6_logging模块
  • 原文地址:https://www.cnblogs.com/wangluojisuan/p/3412095.html
Copyright © 2011-2022 走看看