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要求方法中赋值,调用前随意

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值