假设我有一个类定义为
class Object
{
public int ID { get;set; }
public string Property { get; set; }
public override bool Equals(object obj)
{
Object Item = obj as Object;
return Item.ID == this.ID;
}
public override int GetHashCode()
{
int hash = 13;
hash = (hash * 7) + ID.GetHashCode();
return hash;
}
}
还有两个列表,定义如下:
List<Object> List1;
List<Object> List2;
这两个列表包含ID
字段可能相同的对象,但Property
字段可能相同也可能不同。我希望得到包含在任何这些列表中的所有对象以及属性“1”“1”`中包含的所有List1
对象List2, with the condition that
的field must be set to
结果if it is set to
。结果必须包含不同的值(不同的 ID)。
例如,如果我们有 2 个这样的列表:
List1
-----
ID = 0, Property = "1"
ID = 1, Property = ""
ID = 2, Property = "1"
ID = 3, Property = ""
List2
-----
ID = 1, Property = "1"
ID = 2, Property = ""
ID = 3, Property = ""
我需要一个看起来像这样的结果:
Result
-------
ID = 0, Property = "1"
ID = 1, Property = "1"
ID = 2, Property = "1"
ID = 3, Property = ""
目前它的工作原理是这样的:
var Result = List1.Except(List2).Concat(List2.Except(List1));
var Intersection = List1.Intersect(List2).ToList();
Intersection.ForEach(x => {
x.Property = List1.Single(y => y.ID == x.ID).Property == "1" ? "1" : List2.Single(y => y.ID == x.ID).Property == "1" ? "1" : "";
});
Result = Result.Concat(Intersection);
...但是 ForEach 非常慢。有人可以建议一种更快的方法吗?