如果我们想从方法中获取值,我们可以使用任一返回值,如下所示:
public int GetValue();
或:
public void GetValue(out int x);
我不太明白它们之间的区别,所以不知道哪个更好。你能给我解释一下吗?
谢谢。
最佳答案
返回值几乎总是当方法没有其他任何东西要返回时的正确选择。 (事实上 ,如果我有选择的话,我想不出任何情况我曾经想要一个带有out
参数的void方法。C# 7的Deconstruct
语言支持的解构方法是该规则的一个非常非常罕见的异常(exception)。)
除此之外,它使调用者不必单独声明变量:
int foo;
GetValue(out foo);
对比
int foo = GetValue();
Out 值也可以防止这样的方法链接:
Console.WriteLine(GetValue().ToString("g"));
(事实上,这也是属性 setter 的问题之一,这就是构建器模式使用返回构建器的方法的原因,例如 myStringBuilder.Append(xxx).Append(yyy)
。 )
此外,out 参数稍微难以与反射一起使用,通常也会使测试更加困难。 (通常要付出更多的努力才能使模拟返回值比输出参数更容易)。基本上,我想不出它们能让更容易...
返回值 FTW。
编辑:就正在发生的事情而言......
基本上,当您为“out”参数传递参数时,您必须传递一个变量。 (数组元素也被归类为变量。)您调用的方法在其堆栈上没有用于参数的"new"变量 - 它使用您的变量进行存储。变量中的任何更改都会立即可见。这是显示差异的示例:
using System;
class Test
{
static int value;
static void ShowValue(string description)
{
Console.WriteLine(description + value);
}
static void Main()
{
Console.WriteLine("Return value test...");
value = 5;
value = ReturnValue();
ShowValue("Value after ReturnValue(): ");
value = 5;
Console.WriteLine("Out parameter test...");
OutParameter(out value);
ShowValue("Value after OutParameter(): ");
}
static int ReturnValue()
{
ShowValue("ReturnValue (pre): ");
int tmp = 10;
ShowValue("ReturnValue (post): ");
return tmp;
}
static void OutParameter(out int tmp)
{
ShowValue("OutParameter (pre): ");
tmp = 10;
ShowValue("OutParameter (post): ");
}
}
结果:
Return value test...
ReturnValue (pre): 5
ReturnValue (post): 5
Value after ReturnValue(): 10
Out parameter test...
OutParameter (pre): 5
OutParameter (post): 10
Value after OutParameter(): 10
不同之处在于“后”步骤 - 即在局部变量或参数已更改之后。在 ReturnValue 测试中,这对静态 value
变量没有影响。在 OutParameter 测试中,value
变量由 tmp = 10;
关于c# - 哪个更好,返回值或输出参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/810797/