C#方法传参原理(内存地址原理剖析)
Posted Nemo_XP
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#方法传参原理(内存地址原理剖析)相关的知识,希望对你有一定的参考价值。
在C#中,方法中的参数,不管是值类型如int和stuct,还是string,它都可以理解为复制传值,不会影响原值,如果想改变原值,可以使用引用传参,或者return重新赋值给原变量。
C#方法里的参数,在使用的时候传参有两种
1.普通传参
2.引用传参ref和out
普通传参(值类型:int为例)
地址原理:
PS:在监视中,我们使用“*变量名”来获取变量的地址。"&变量名"来获取此变量的值和地址(之前有文章介绍过地址就是一段内存的门牌号,内存里存的是变量的值,而变量是我们给门牌号起的昵称)
值类型比较好理解,因为线程栈中值类型如int,存的是数据,方法使用的也是一个新的内存新的变量,他们并不相同,所以方法里的变量怎么变,都不会影响方法外的值类型变量。
而引用类型传递的是地址,那是不是就直接就改变原值了呢?看下面这个例子。
普通传参(引用类型:自定义类Person为例)
namespace Test
{
class Person
{
public string state;
}
class Program
{
static void Main(string[] args)
{
Person p = new Person();
p.state = "生病了";
SeeDoctor(p);
}
static void SeeDoctor(Person pArgs)
{
pArgs.state = "治好了";
}
}
}
如上可以,我们传递引用类型的时候,因为传递的是地址,哪怕p和pArgs不是同一个对象,但是他们指向了同一个堆空间,你变我也变。
但是引用类型中有一个特例是string是不太一样的。这里我们看一下直接传递p.state会怎样.为了好理解我简化为普通的string,其实效果是一样的.
普通传参(引用类型:特殊的string)
到这里和引用类型person完全一致,同时指向一块一个内存空间0x02e48e58.
之后,str赋值病好了,因为字符串不可变性,需要重新开辟一块内存空间放入"病好了",并把新地址0x02ed9758指给str。而原内存空间0x02e48e58里依旧是"生病了",此时已与str断了联系,然而我们在方法中它只有重新指向str的权限,动不了state的指向,state依然是生病了的.因此回到主代码中,state依旧是生病了。
由于引用类型有此特殊性,所以我们可以把它等同于值类型在参数中使用。
那我们再处理值类型和string的时候如何才能得到改变后的值呢。
引用传参ref或out
地址原理
或者使用return返回值
class Program
{
static void Main(string[] args)
{
int n = 10;
Func(n);
}
static int Func(int num)
{
num = 50;
return num;
}
}
引用传参ref和out的区别:
ref要求使用前先赋值,方法中随意
out要求方法中赋值,调用前随意
以上是关于C#方法传参原理(内存地址原理剖析)的主要内容,如果未能解决你的问题,请参考以下文章