如何解决嵌套对象初始化程序似乎无效,但可以编译
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”最终会出现在两个不同的列表中。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。