zoukankan      html  css  js  c++  java
  • 指针数组 vs 数组指针

        指针数组,故名思义,就是指针的数组,数组的元素是指针;
        数组指针,同样,就是直想数组的指针。

        简单举例说明:

        int *p[2]; 首先声明了一个数组,数组的元素是int型的指针。
        int (*p)[2]; 声明了一个指针, 指向了一个有两个int元素的数组。

        其实这两种写法主要是因为运算符的优先级, 因为[]的优先级比*高。所以第一种写法,p先和[]结合,所以是一个数组,后与*结合,是指针。后一种写法同理。
        指针数组如下处理就会很清楚:
        typedef int* intPtr;
        intPtr p[2]; 
        一目了然,所以为了避免迷惑,做适当的typedef也是很有必要的。
        同理,数组指针也可以作类似处理:
        typedef int intArray2[2];
        intArray2 * p;
        和原来的声明都是等价的。
        

    指针数组:array of pointers,即用于存储指针的数组,也就是数组元素都是指针

    数组指针:a pointer to an array,即指向数组的指针

    还要注意的是他们用法的区别,下面举例说明。

    int* a[4]     指针数组    

                     表示:数组a中的元素都为int型指针   

                     元素表示:*a[i]   *(a[i])是一样的,因为[]优先级高于*

    int (*a)[4]   数组指针    

                     表示:指向数组a的指针

                     元素表示:(*a)[i] 

    注意:在实际应用中,对于指针数组,我们经常这样使用:

    1
    2
    typedef int* pInt;
    pInt a[4];

    这跟上面指针数组定义所表达的意思是一样的,只不过采取了类型变换。

    代码演示如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    #include <iostream>
     
    using namespace std;
     
    int main()
    {
    int c[4]={1,2,3,4};
    int *a[4]; //指针数组
    int (*b)[4]; //数组指针
    b=&c;
    //将数组c中元素赋给数组a
    for(int i=0;i<4;i++)
    {
    a[i]=&c[i];
    }
    //输出看下结果
    cout<<*a[1]<<endl; //输出2就对
    cout<<(*b)[2]<<endl; //输出3就对
    return 0;
    }

    注意:

    1.上文中的a和b的定义也可以换成:

    typedef int * intPointer;
    typedef int arraypointer[4];

    intPointer a[4];
    arraypointer* b;

    2.定义了数组指针,该指针指向这个数组的首地址,必须给指针指定一个地址,容易犯的错得就是,不给b地址,直接用(*b)[i]=c[i]给数组b中元素赋值,这时数组指针不知道指向哪里,调试时可能没错,但运行时肯定出现问题,使用指针时要注意这个问题。但为什么a就不用给他地址呢,a的元素是指针,实际上for循环内已经给数组a中元素指定地址了。但若在for循环内写*a[i]=c[i],这同样会出问题总之一句话,定义了指针一定要知道指针指向哪里,不然要悲剧。

    类似的还有指针函数和函数指针,遇到了再说吧。


  • 相关阅读:
    ehcache memcache redis 三大缓存男高音
    tomcat启用压缩的方式
    Linux rpm 命令参数使用详解[介绍和应用]
    rpm常用命令及rpm参数介绍
    RPM 命令大全
    BZOJ2298: [HAOI2011]problem a(带权区间覆盖DP)
    BZOJ2037: [Sdoi2008]Sue的小球(区间DP)
    HDU3507 Print Article(斜率优化DP)
    线性代数学习笔记(几何版)
    HDU 2065 "红色病毒"问题(生成函数)
  • 原文地址:https://www.cnblogs.com/jiayouwyhit/p/3259868.html
Copyright © 2011-2022 走看看