我正在尝试找出两个泛型列表之间的区别,如下面的示例所示。尽管t1和t2包含相同的属性,但它们不是相同的对象,因此我需要实现一个IEqualityComparer。
这似乎适用于这个示例,但真正的类有几个其他属性,我还需要对其他几个类执行相同的操作。
所以我想知道我是不是在重新发明轮子?
有没有更简单的方法来比较两个对象的所有属性?目前,我真的只需要处理包含简单类型的类,但如果我有一个比较器来处理包含其他类的实例的类,那就太好了。
void Main()
{
var t1 = new Sizes { Name = "Test" , Size = 1} ;
var t2 = new Sizes { Name = "Test" , Size = 1} ;
var list1 = new List<Sizes>();
var list2 = new List<Sizes>();
list1.Add(t1);
list2.Add(t2);
var differences = list2.Except(list1 , new SizesComparer());
// differences should be empty.
}
public class Sizes
{
public string Name { get; set; }
public int Size { get; set; }
}
public class SizesComparer : IEqualityComparer<Sizes>
{
bool IEqualityComparer<Sizes>.Equals(Sizes x, Sizes y)
{
return (x.Name.Equals(y.Name) && x.Size.Equals(y.Size));
}
int IEqualityComparer<Sizes>.GetHashCode(Sizes obj)
{
if (Object.ReferenceEquals(obj, null))
return 0;
return obj.Name.GetHashCode() + obj.Size;
}
}
发布于 2011-08-18 03:05:20
我最终使用的解决方案不能被描述为快速,但这不是我关心的问题,它做了我想要的事情,因为它可以被重用,并且不限于任何特定的类。
它使用Newtonsoft.Json库将对象序列化为字符串,然后比较结果。这也有处理匿名类和嵌套类的优点。
我假设比较的方式是,它首先在两个对象上调用GetHashCode,如果它们匹配,则调用Equals,这在这个例程中意味着匹配的对象将被序列化两次。
public class JSonEqualityComparer<T> : IEqualityComparer<T>
{
public bool Equals(T x, T y)
{
return String.Equals
(
Newtonsoft.Json.JsonConvert.SerializeObject(x),
Newtonsoft.Json.JsonConvert.SerializeObject(y)
);
}
public int GetHashCode(T obj)
{
return Newtonsoft.Json.JsonConvert.SerializeObject(obj).GetHashCode();
}
}
public static partial class LinqExtensions
{
public static IEnumerable<T> ExceptUsingJSonCompare<T>
(this IEnumerable<T> first, IEnumerable<T> second)
{
return first.Except(second, new JSonEqualityComparer<T>());
}
}
要使用它,除了与ExceptUsingJSonCompare一起使用外,还可以交换,例如:
var differences = list2.ExceptUsingJSonCompare(list1);
发布于 2011-08-12 23:15:35
您可以尝试如下所示:
var differences = list2.Where(l2 =>
!list1.Any(l1 => l1.Name == l2.Name && l1.Size == l2.Size));
或者,如果您愿意:
var differences = list2.Where(l2 =>
list1.All(l1 => l1.Name != l2.Name || l1.Size != l2.Size));
https://stackoverflow.com/questions/7042090
复制相似问题