关于C#的ref引用传参描述怎样理解比较好
比如我们都知道参数是放到内存里面.两个参数,比如我现在有两个箱子,一个苹果箱里面有苹果,一个梨子箱里面有梨子.如果不使用ref引用传参,就等于我把苹果和梨子从箱子里面拿了...
比如我们都知道参数是放到内存里面.两个参数,比如我现在有两个箱子,一个苹果箱里面有苹果,一个梨子箱里面有梨子.
如果不使用ref引用传参,就等于我把苹果和梨子从箱子里面拿了出来,交给你,你无论怎么对苹果梨子进行调换,与我无关,我拿回来的时候就会按正确的方式去放,.
如果我加上了ref之后,就可以看成一种新的数据类型,连带箱子一起给你,这个时候,你把里面的东西交换,而我拿回来的时候是拿箱子,里面内容怎么样跟我没关系,再输出值就会产生交换的效果. 展开
如果不使用ref引用传参,就等于我把苹果和梨子从箱子里面拿了出来,交给你,你无论怎么对苹果梨子进行调换,与我无关,我拿回来的时候就会按正确的方式去放,.
如果我加上了ref之后,就可以看成一种新的数据类型,连带箱子一起给你,这个时候,你把里面的东西交换,而我拿回来的时候是拿箱子,里面内容怎么样跟我没关系,再输出值就会产生交换的效果. 展开
展开全部
这个例子笼统来看,是正确的,但举得确实不怎么高明,如果用它来理解ref,分明有越搅越浑之嫌。如果严格来看,这个例子甚至是不正确的。
我们知道,C#里的数据类型分为两类,一是值类型,一是引用类型。ref只针对值类型使用。值类型有一个最大的特点,就是你把它赋给任何“人”,它都是采用“复制”方式。如果我们也举一个例子,相当于有人来找你出去,作为值类型的你并没有亲自去,而是临时“克隆”了一个自己,派这个“克隆你”去。结果是如何呢?那个克隆的你在外面不管发生了什么事,玩嗨了也好,受伤了也罢,都不会影响你。引用类型就不同了,引用类型的你总是“亲力亲为”,谁叫你你都亲自去,所以任何变化都发生在自己身上。
那么有时候,程序员也希望值类型的你能够直接一些,叫你去就是想对你做些改变,怎么办呢?那就要用ref修饰来明确告诉你,你必须亲自来。当然了,你亲自去的后果就是有什么玩嗨了,受伤了的事情,就直接承受在你自己身上。
总结来说呢,你可以认为,一个加了ref的值类型参数,你可以临时把它看成是一个引用类型。
写完之后,发现这个例子好像也不是特别生动,倒有些恐怖,不知道对你有没有帮助。
我们知道,C#里的数据类型分为两类,一是值类型,一是引用类型。ref只针对值类型使用。值类型有一个最大的特点,就是你把它赋给任何“人”,它都是采用“复制”方式。如果我们也举一个例子,相当于有人来找你出去,作为值类型的你并没有亲自去,而是临时“克隆”了一个自己,派这个“克隆你”去。结果是如何呢?那个克隆的你在外面不管发生了什么事,玩嗨了也好,受伤了也罢,都不会影响你。引用类型就不同了,引用类型的你总是“亲力亲为”,谁叫你你都亲自去,所以任何变化都发生在自己身上。
那么有时候,程序员也希望值类型的你能够直接一些,叫你去就是想对你做些改变,怎么办呢?那就要用ref修饰来明确告诉你,你必须亲自来。当然了,你亲自去的后果就是有什么玩嗨了,受伤了的事情,就直接承受在你自己身上。
总结来说呢,你可以认为,一个加了ref的值类型参数,你可以临时把它看成是一个引用类型。
写完之后,发现这个例子好像也不是特别生动,倒有些恐怖,不知道对你有没有帮助。
追问
感谢,调试的时候其实看到不用ref修饰后内存地址是不相同的,我就感觉我的那个例子有些不恰当,但是跳转到函数里面后,原来的内存地址是不可用的,就让我很纠结
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询