5

示例 1:

SomeObject someObject = new SomeObject();
if (someObject.Method())
{
    //do stuff
}
//someObject is never used again

对比

示例 2:

if (new SomeObject().Method())
{
    //do stuff
}

使用第一种方法比第二种方法有什么好处,反之亦然?

4

4 回答 4

12

至少有三个潜在的好处:

  1. 可读性:在许多情况下,第一个比第二个示例的语法更明显,尤其是对于新开发人员而言。

  2. 更好的调试体验:如果 for 的构造函数SomeObject抛出异常,在第一种情况下,调试器会在该行中断。在第二种情况下,异常是在构造函数中还是在方法中并不明显。设置断点和检查对象上的值也会出现同样的问题 - 这在第二种情况下会很困难,并且需要在方法内部设置断点。

  3. 在第一种情况下,您可以在该单个调用之外使用该对象。如果你真的只需要一个方法来进行一次调用,而不需要对象引用,那么静态方法可能更合适。

于 2010-06-18T20:52:34.990 回答
3

在大多数微不足道的情况下,编译器无论如何都会删除它。值类型有一点很重要,就是将其复制到变量中会克隆值,因此可以表示重大变化 - 但无论如何您都不应该鼓励可变值类型。

对于浮点,在某些极端情况下,当它使用本地时,您会得到不同的答案(本机类型的宽度大于Single/Double等) - 这也意味着您可以通过调试/发布获得不同的结果(取决于变量被编译器删除)。

在某些情况下,变量可以做的不仅仅是堆栈上的值 - 即被“捕获”到 lambda / anon-method,或用于out/ ref,但这很少适用。

于 2010-06-18T20:57:15.233 回答
2

在调试以查看值时可能很有用(并且如果对象是 COM 互操作或类似的东西,您需要处理它可能很重要,以便您能够在受控的情况下执行此操作方式)。

如果名称很长或者有多层嵌套,它也更容易阅读。

于 2010-06-18T20:52:12.120 回答
0

我倾向于第一个选项以提高可读性,例如:

var phoneNumberRx = new Regex(@"^\(\d{3}\)\d{3}-\d{4}$");
于 2010-06-18T20:57:35.093 回答