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#方法传参原理(内存地址原理剖析)的主要内容,如果未能解决你的问题,请参考以下文章

socket收发消息原理剖析

深度剖析fork()的原理及用法

游戏外挂原理解析与制作 - [内存数值修改类 篇四]

多态实现原理剖析

游戏外挂原理解析与制作 - [内存数值修改类 篇二]

JAVA并发编程——源码原理全面剖析与重点梳理