问题描述
ref在传递引用类型的参数时起到的作用是什么?
解决方案
解决方案二:
1.ref关键字使参数按引用传递。2.其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。3.使用ref参数,方法定义和调用方法都必须显式使用ref关键字4.传递到ref参数的参数必须最先初始化。
解决方案三:
可以改变传入变量的值比如test(refstrings)可以改变s的值,而没有ref的话,你即便在函数内部改变了s,出了函数体,s还会恢复传入的值
解决方案四:
ref一般是传递值类型的参数吧,意思是将值类型的参数按引用类型参数来传递.引用类型还需要ref吗??!
解决方案五:
嗯,傳入一個值,在函數體中改變它,結束之后,該改變保存
解决方案六:
学习了!!谢谢!!
解决方案七:
引用1楼ojlovecd的回复:
1.ref关键字使参数按引用传递。2.其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。3.使用ref参数,方法定义和调用方法都必须显式使用ref关键字4.传递到ref参数的参数必须最先初始化。
同意
解决方案八:
可以改变传入变量的值比如test(refstrings)可以改变s的值,而没有ref的话,你即便在函数内部改变了s,出了函数体,s还会恢复传入的值如:s=10;test(refstrings){s=30;}prentfs;如果不加ref那么s最后的值是10;如果加ref那么随后的值是30;
解决方案九:
引用3楼mohugomohu的回复:
ref一般是传递值类型的参数吧,意思是将值类型的参数按引用类型参数来传递.引用类型还需要ref吗??!
在c/s模式下即使引用类型也是要加ref的,以保证服务器端的修改能传回客户端
解决方案十:
具体可看msdn。
解决方案十一:
ref关键字使参数按引用传递。其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。若要使用ref参数,则方法定义和调用方法都必须显式使用ref关键字。例如:复制代码classRefExample{staticvoidMethod(refinti){i=44;}staticvoidMain(){intval=0;Method(refval);//valisnow44}}传递到ref参数的参数必须最先初始化。这与out不同,out的参数在传递之前不需要显式初始化。(请参见out。)尽管ref和out在运行时的处理方式不同,但它们在编译时的处理方式是相同的。因此,如果一个方法采用ref参数,而另一个方法采用out参数,则无法重载这两个方法。例如,从编译的角度来看,以下代码中的两个方法是完全相同的,因此将不会编译以下代码:复制代码classCS0663_Example{//compilererrorCS0663:"cannotdefineoverloaded//methodsthatdifferonlyonrefandout"publicvoidSampleMethod(refinti){}publicvoidSampleMethod(outinti){}}但是,如果一个方法采用ref或out参数,而另一个方法不采用这两类参数,则可以进行重载,如下所示:复制代码classRefOutOverloadExample{publicvoidSampleMethod(inti){}publicvoidSampleMethod(refinti){}}备注属性不是变量,因此不能作为ref参数传递。有关传递数组的信息,请参见使用ref和out传递数组。示例按引用传递值类型(如上所示)是有用的,但是ref对于传递引用类型也是很有用的。这允许被调用的方法修改该引用所引用的对象,因为引用本身是按引用来传递的。下面的示例显示出当引用类型作为ref参数传递时,可以更改对象本身。复制代码classRefRefExample{staticvoidMethod(refstrings){s="changed";}staticvoidMain(){stringstr="original";Method(refstr);//strisnow"changed"}}
解决方案十二:
ref关键字使参数按引用传递。
解决方案十三:
classX{voidM1(intv){v=100;}voidM2(refintv){v=100;}}...staticvoidMain(){Xx=newX();intv=999;x.M1(v);//这时v还是999,进入时参数值为999一个v的copyx.M2(refv);//这时v是100,进入时为v的引用,值为999,值和上面一样}本来值传到方法中时是传的copy,但加了ref就是传这个值的地址(引用)
解决方案十四:
引用传递,这样在其它方法里可以一起修改变量