当我使用下面的方法时,当此列表为空时,将创建该列表并添加一条记录,但列表仍然为空的方法。如何使用ac#扩展方法添加到列表以及创建列表
但是,如果列表已经创建,那么我看到列表增长超出了方法。
public static void Add(this List<Setting> Settings, object Name, object Value)
{
if(null==Settings)
{
Settings = new List<Setting>();
}
var item = Settings.FirstOrDefault(s => s.Name.ToLower() == Name.ToString().ToLower());
if (null != item)
{
//overwrite the value of an existing item
item.Value = Value.ToString();
}
else
{
//Add the new Setting to the list
Settings.Add(new Setting(Name.ToString(), Value.ToString()));
}
}
这对我来说似乎是一种反模式。从https://msdn.microsoft.com/en-us/library/bb383977.aspx开始:“一般来说,我们建议您谨慎实施扩展方法,并且只在必要时才执行。只要有可能,客户端代码必须扩展现有类型应该通过创建一个从现有类型派生的新类型来实现。有关更多信息,请参见继承(C#编程指南)。 – JamieSee
对我而言,真正突出的是它是一个正试图重新分配自己的对象的扩展方法。如果你的代码试图将'this'设置为别的东西,这不是一件好事。 – moarboilerplate
对于我来说,让这个方法放在一个空引用上更直观,因为将某些东西添加到空白是没有意义的。 – Setsu