比方说,我们有一个带有私有列表的泛型类。我们至少可以通过两种方式让它返回这个列表的只读包装器:
public class Test<T>
{
public List<T> list = new List<T>();
public IEnumerable<T> Values1
{
get
{
foreach (T i in list)
yield return i;
}
}
public IEnumerable<T> Values2
{
get
{
return list.AsReadOnly();
}
}
}
Values1
和Values2
都会反映基础集合中的任何更改,并阻止其通过自身进行修改。
哪种方式更可取?你应该意识到什么?或者还有其他更好的方法吗?
发布于 2012-10-02 09:30:26
如果输出只需要一个IEnumerable<T>
,我更倾向于:
public IEnumerable<T> Values
{
return this.list.AsReadOnly();
}
由于ReadOnlyCollection
实现了IEnumerable<T>
,这为您的对象提供了一个安全的包装器,同时仍然是灵活和有效的,并防止强制转换能够设置值。
如果您决定要在结果中做一些不同的事情,您可以随时更改内部实现。
https://stackoverflow.com/questions/12683352
复制相似问题