我一直试图弄清楚这些构造函数之间是否存在任何差异。假设有一个不带参数的Foo()构造函数,所有这些构造函数都会有相同的结果吗?
public Foo()
: this()
{
blah;
blah;
blah;
}
public Foo()
{
this();
blah;
blah;
blah;
}
public Foo()
{
this = new Foo();
blah;
blah;
blah;
}
答案 0 :(得分:32)
我会避免在结构中分配this
。从其他答案中可以看出,它的可能性很少被人知道(我只知道因为它在规范中出现了一些奇怪的情况)。你已经得到它,它没有任何好处 - 在其他地方它可能会改变结构,这是不一个好主意。结构应始终是不可变的:)
编辑:只是为了让人们“流泪”!一点点 - 分配给this
与仅链接到另一个构造函数并不完全相同,因为您也可以在方法中执行:
using System;
public struct Foo
{
// Readonly, so must be immutable, right?
public readonly string x;
public Foo(string x)
{
this.x = x;
}
public void EvilEvilEvil()
{
this = new Foo();
}
}
public class Test
{
static void Main()
{
Foo foo = new Foo("Test");
Console.WriteLine(foo.x); // Prints "Test"
foo.EvilEvilEvil();
Console.WriteLine(foo.x); // Prints nothing
}
}
答案 1 :(得分:11)
示例2和3不合法C#。
编辑:当Foo
是struct
时,Jon准确地指出3是合法的。去看看他的回答!
答案 2 :(得分:4)
不,他们不会,因为只有第一个构造函数实际上是合法的。其他两个因各种原因是非法的。
编辑有趣的是,当Foo是一个结构时,3确实合法。但即使在这种情况下,这也是一项冗余任务。