底层解析C指针(一)

描述

指针是C语言中的精髓部分,同样也是C语言的难点所在,下面从最底层来分析C指针。

首先先放节论,这样可能会节省部分人的阅读时间。

对于一级指针:

C语言

对于二级指针:

C语言

同理我们有:

n级指针

C语言

需要注意的是,上面的所有指针都需要初始化,如果看懂了上面的图,也就知道为什么必须初始化的原因了,其实指针实质上是不存在的,编译器会将其全部替换为地址,正因为如此,导致很多初学者被各种符号晕头转向,如同普通变量一样,指针也是一种变量,说到底,变量其实也不存在,在编译器编译的过程中,所有的变量会被替换掉,真正有用的只是变量的值, 如果想详细了解此类容,读者可以看编译原理这本书。

下面我们来验证上面的结论

C语言

上面我采用了直接强制转换的方式来分配地址,这个并不是每次执行都会成功,原因是强行分配的地址很可能恰好被使用或者是内存碎片再或者没有进行字节对齐,这些都会导致强行分配地址时失败,因此可以多进行测试,下面得到输出。

C语言

现在无法知道,为了直观,我们直接打开Debug调试,同时设置断点,现在我们打开Memory dump,如图所示

C语言

x86结构的内存结构为大端模式,低字节放到高地址。

此时我们输入0x60fef2,点击"GO",可以看到内存中的数据如下图所示:

C语言

可以看到内存地址为0x60fef2处的数据为5

然后输入0x60fefc点击"GO",可以看到内存中的数据如下图所示:

C语言

可以看到内存地址为0x60fefc处的数据为0x60fef2

可以看到这个完全符合上面的节论,

需要说明的是,我们写程序时虽然使用了 p, &p, *p这三个符号,但是计算机编译过程中只有两个有用的数据

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分