C# Ref关键字
C# 语言参考
ref(C# 参考)
** ref ** 关键字使参数按引用传递。其效果是,当控制权传递回调用方法时,在方法中对参数所做的任何更改都将反映在该变量中。若要使用 ** ref ** 参数,则方法定义和调用方法都必须显式使用 ** ref ** 关键字。例如:
[
复制代码 ](javascript:CopyCode(‘ctl00_LibFrame_ctl06other’)😉
class RefExample
{
static void Method(ref int i)
{
i = 44;
}
static void Main()
{
int val = 0;
Method(ref val);
// val is now 44
}
}
传递到 ** ref ** 参数的参数必须最先初始化。这与 out 不同,out 的参数在传递之前不需要显式初始化。(请参见 out
。)
尽管 ** ref ** 和 ** out ** 在运行时的处理方式不同,但它们在编译时的处理方式是相同的。因此,如果一个方法采用 ** ref **
参数,而另一个方法采用 [ out ](http://msdn2.microsoft.com/zh-
cn/library/t3c3bfhx(VS.80).aspx)
参数,则无法重载这两个方法。例如,从编译的角度来看,以下代码中的两个方法是完全相同的,因此将不会编译以下代码:
[
复制代码 ](javascript:CopyCode(‘ctl00_LibFrame_ctl09other’)😉
class CS0663_Example
{
// compiler error CS0663: "cannot define overloaded
// methods that differ only on ref and out"
public void SampleMethod(ref int i) { }
public void SampleMethod(out int i) { }
}
但是,如果一个方法采用 ** ref ** 或 [ out ](http://msdn2.microsoft.com/zh-
cn/library/t3c3bfhx(VS.80).aspx) 参数,而另一个方法不采用这两类参数,则可以进行重载,如下所示:
[
复制代码 ](javascript:CopyCode(‘ctl00_LibFrame_ctl11other’)😉
class RefOutOverloadExample
{
public void SampleMethod(int i) { }
public void SampleMethod(ref int i) { }
}
[ ![备注](http://msdn2.microsoft.com/msdn/Controls/CollapsibleArea/en-
us/minus.gif) 备注 ](http://msdn2.microsoft.com/zh-
cn/library/14akc2c7(VS.80).aspx#)
属性不是变量,因此不能作为 ** ref ** 参数传递。
有关传递数组的信息,请参见
[ 使用 ref 和 out 传递数组 ](http://msdn2.microsoft.com/zh-
cn/library/szasx730(VS.80).aspx) 。
[ ![示例](http://msdn2.microsoft.com/msdn/Controls/CollapsibleArea/en-
us/minus.gif) 示例 ](http://msdn2.microsoft.com/zh-
cn/library/14akc2c7(VS.80).aspx#)
按引用传递值类型(如上所示)是有用的,但是 ** ref **
对于传递引用类型也是很有用的。这允许被调用的方法修改该引用所引用的对象,因为引用本身是按引用来传递的。下面的示例显示出当引用类型作为 ** ref **
参数传递时,可以更改对象本身。
class RefRefExample
{
static void Method(ref string s)
{
s = "changed";
}
static void Main()
{
string str = "original";
Method(ref str);
// str is now "changed"
}
}
[
复制代码 ](javascript:CopyCode(‘ctl00_LibFrame_ctl15other’)😉