问题描述
public List<string> TestProperty => new List<string> {"one","two"};
并尝试使用
在对象初始化程序中对其进行初始化
TestProperty = new List<string> {"three","four"}
我得到预期的错误:
[CS0200] Property or indexer 'X.TestProperty' cannot be assigned to -- it is read only
但是,如果我尝试使用对象初始化程序来初始化它
TestProperty = { "three","four" }
一切正常,但该属性仍返回new List<string> {"one","two"};
。
编辑:请注意,我不想初始化此属性,我担心的是编译器允许发生看起来像初始化的事情。
解决方法
假设您有这个:
public class X
{
public List<string> TestProperty => new List<string> {"one","two"};
}
然后:
public static void Main()
{
var x = new X
{
TestProperty = { "a","b" }
};
}
大致可编译为:
var x = new X();
var list = x.TestProperty; // remember,this is a NEW list
list.Add("a");
list.Add("b");
因此,当您打印(或在调试器中查看)x.TestProperty
时,这是一个全新的列表,因此您添加的值实际上被忽略了。
为什么该语法有效?因为该功能的设计目的是使您通常在构造函数中生成一个空列表,并且Add
调用将添加到该列表中。在这种情况下,您唯一的决定就是放弃这些值,因为您可以使用备用字段来代替返回新实例。
@madreflection通过this SharpLab正确地指出,对Add
的每次调用将在调用x.TestProperty
之后进行,因此“ a”和“ b”最终会出现在两个不同的列表中。