本文共 513 字,大约阅读时间需要 1 分钟。
一.引用的底层原理实现
什么是引用?
引用实际是存放的对象的地址
引用占内存吗?
采用如下例子:
可以看到直接对b取地址符,得到的值和a的地址一样!之前以为这样就说明a和b是同一个内容,即b不占用内存。
其实不然:看下面一个例子
可以看出:
结构体sizeof为8,说明引用自己占用内存的;
(*ptr)从某种角度也是一种引用,因此可以认为对引用取地址实际是对引用对象取地址。a.val的地址我们没法通过&(a.val)获得,因为编译器会将&b解释为:&(*a.val) =&a.v ,所以&a.val将得到&a.v。也验证了对所有的a.val的操作,和对a.v的操作等同。
如果大家有比较好的取的a.val的地址的方法,可以提出!
引用和二级指针
引用的地址实际可以看作一个二级指针,因为引用里面实际存的是对象的地址。
因此有过程:1.*(引用地址)=对象地址
2. *(对象地址)=对象
3. **(引用地址)=对象
引用就是编译器需要执行第二步和第三步,程序员就直接使用引用即可;因此像很多参数传引用(比如递归)的地方,实际也可以用二级指针代替,只是对于引用而言,上述过程编译器会执行,而二级指针需自己动手实现上述转换。
转载地址:https://blog.csdn.net/weixin_40599276/article/details/97276888 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!