指针是C语言中的精髓部分,同样也是C语言的难点所在,下面从最底层来分析C指针。
首先先放节论,这样可能会节省部分人的阅读时间。
对于一级指针:
对于二级指针:
同理我们有:
n级指针
需要注意的是,上面的所有指针都需要初始化,如果看懂了上面的图,也就知道为什么必须初始化的原因了,其实指针实质上是不存在的,编译器会将其全部替换为地址,正因为如此,导致很多初学者被各种符号晕头转向,如同普通变量一样,指针也是一种变量,说到底,变量其实也不存在,在编译器编译的过程中,所有的变量会被替换掉,真正有用的只是变量的值,如果想详细了解此类容,读者可以看编译原理这本书。
下面我们来验证上面的结论
上面我采用了直接强制转换的方式来分配地址,这个并不是每次执行都会成功,原因是强行分配的地址很可能恰好被使用或者是内存碎片再或者没有进行字节对齐,这些都会导致强行分配地址时失败,因此可以多进行测试,下面得到输出。
现在无法知道,为了直观,我们直接打开Debug调试,同时设置断点,现在我们打开Memory dump,如图所示
x86结构的内存结构为大端模式,低字节放到高地址。
此时我们输入0x60fef2,点击"GO",可以看到内存中的数据如下图所示:
可以看到内存地址为0x60fef2处的数据为5
然后输入0x60fefc点击"GO",可以看到内存中的数据如下图所示:
可以看到内存地址为0x60fefc处的数据为0x60fef2
可以看到这个完全符合上面的节论,
需要说明的是,我们写程序时虽然使用了 p, &p, *p这三个符号,但是计算机编译过程中只有两个有用的数据