码迷,mamicode.com
首页 > 其他好文 > 详细

指向指针的指针

时间:2014-05-12 23:22:28      阅读:291      评论:0      收藏:0      [点我收藏+]

标签:指针   内存分配   二级指针   

理解二级指针,关键是理解指针的存储方式和意义。

这里以指向int型指针的指针为例,梳理一下二级指针在内存分配中 的奥妙....

#include <iostream>
using namespace std;

int main()
{
    int a[5] = {1, 2, 3, 4, 5};
    int *p = a;
    int **point = &p;

    cout << "a = " << a << endl
        << "p = " << p << endl
        << "&p = " << &p << endl
        << "point = " << point << endl
        << "&point = " << &point << endl;

    for (int i = 0; i < 5; i++)
    {
        cout << "&a[" << i << "] = " << &a[i] << endl;
    }
    return 0;
}

运行结果:

bubuko.com,布布扣


看一下内存分配图:

bubuko.com,布布扣

从上图可以看出point指针中存放的是p指针的地址,而p指针中存放的是a[0]的地址。所以*point和p是一样的,前者是取point指针中存放的地址(0025F754)中的值,即取地址0025F754中存放的值(0025F760),而后者就是0025F760,所以两者是等价的。

**point和a[0]是等价的,前者可以写成*p,*p是取p中存放的地址(0025F760)中的值,即地址0025F760中存放的值1。由上可以得出*point等于p, **point 等于 a[0]。通过上图可以清晰的对付诸如*point++等问题。


指向指针的指针,布布扣,bubuko.com

指向指针的指针

标签:指针   内存分配   二级指针   

原文地址:http://blog.csdn.net/hustyangju/article/details/25622523

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!