时间:2021-05-19
花了很长时间的实践,终于搞清楚了。类或者链表等,在指针赋值的时候,会使用新的指针。比如:
Foo a = c;Foo b = new Foo();Foo a = b;这种情况下,会把b的指针传给a,a不再指向c,a以后的操作都会对b生效。
如下情况下:
这种情况下,表示a无法被修改,但是如果你a.bar = 5;的话,那么是可以修改的,为什么呢?因为此时任何针对a的属性的修改,本质上都是对b的修改,只有a = c;是不可以的。可以简单理解为a = c;是指针的赋值,而a.bar = 5;只是所指对象的属性发生改变。
综上所述:
如果你希望a是一个仅指向b的替身,那么就可以后后面这个方法了。好处就是,可以随意修改a的属性,也就是b的属性,但是a永远会指向b,不会被篡改。
如果希望多次使用a,那么只能用第一种方法。但是如果搞不清楚用错的话,会经常不小心修改到原始值。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
浅谈先来说一下“this指针”:C++中通过引入this指针解决该问题,暨:C++编译器给每个“非静态的成员函数”增加了一个隐藏的指针参数,让该指针指向当前对象
C#学习笔记-浅谈数组复制,排序,取段,元组usingSystem;usingSystem.Collections.Generic;namespaceAppli
c#调用C++DLL代码,发现了一个隐藏很深的问题。危害很大,而且不易察觉。大概是申明c++的函数时候,有一个long类型的指针。在C#中我的申明成了这样:pu
委托给了C#操作函数的灵活性,我们可使用委托像操作变量一样来操作函数,其实这个功能并不是C#的首创,早在C++时代就有函数指针这一说法,而在我看来委托就是C#的
委托(delegate)是一种可以把引用存储为函数的类型,这类似于c++中的函数指针。回调函数c++中的回调函数,就是用函数指针来实现的。类似的,c#中用委托,