jp2*_*ode 3 c# lambda visual-studio-2010
我有一个"微类",我写了一些快速数据操作.
这是项目:
class AEmp {
public AEmp() {
Parts = new AParts();
}
public string Badge { get; set; }
public AParts Parts { get; set; }
public int Days { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
这是清单:
class AEmps {
private List<AEmp> list;
public AEmps() {
list = new List<AEmp>();
}
public AEmp this[string badge] {
get { return list.SingleOrDefault(e => e.Badge == badge); }
}
public void Add(AEmp item) {
if (!Contains(item.Badge)) {
list.Add(item);
}
}
public bool Contains(string badge) {
return (list.Where(o => o.Badge == badge) != null);
}
public int Count { get { return list.Count; } }
public AEmp Owner(string serialNo, DateTime startDay, DateTime nextDay) {
return (list.SingleOrDefault(e => e.Parts.Contains(serialNo, nextDay)));
}
}
Run Code Online (Sandbox Code Playgroud)
我面临的问题是当我去列表中添加新项目时.我不想添加一个项目,如果它已经存在,所以我用我的Contains方法检查它.
列表为空(Count = 0),因此list.Where(o => o.Badge == badge) != null)应返回FALSE.
对?
我在这做错了什么?
Jon*_*eet 10
对?
错误.空序列表示为......空序列.这与null引用不同.相反,它是一个你可以正常呼叫成员的序列 - 你只是不会得到任何结果.哎呀,因为LINQ很懒,序列甚至不知道是否有任何元素,直到你试图要求它们.Where不可能返回null,仍然懒惰地执行.
我想你想要Any.
return list.Any(o => o.Badge == badge);
Run Code Online (Sandbox Code Playgroud)
请注意,通常情况下,使用空序列(空列表,空数组等)比使用空引用更简洁 - 它允许调用者有一条路径可以以任何方式工作,而不必在每一步检查无效.
| 归档时间: |
|
| 查看次数: |
949 次 |
| 最近记录: |