为了去重复,写了一个通用的比较容器类,可以用在需要比较的地方,且支持Lamda表达式,代码如下:
public class DataComparer<T>:IEqualityComparer<T> where T:class { private Func<T, T, bool> _compareFunc; public DataComparer(Func<T,T,bool> compareFunc) { this._compareFunc = compareFunc; } public bool Equals(T x, T y) { return this._compareFunc(x, y); } public int GetHashCode(T obj) { return obj.ToString().GetHashCode(); } }
调用如下:
dataTable.AsEnumerable().Distinct(new DataComparer<DataRow>((x, y) => return (x[1] == y[1] && x[2] ==y[2]))).CopyToDataTable();
在这里需要特别说明一下,GetHashCode方法重写时,需要使用:obj.ToString().GetHashCode(),而不能直接使用obj.GetHashCode(),原因如下(MSDN):
GetHashCode 方法可以由派生类型重写。 如果 GetHashCode 没有重写,引用类型的哈希代码通过调用基类的 Object.GetHashCode 方法计算,它基于对象的引用的哈希代码计算;有关更多信息,请参见 RuntimeHelpers.GetHashCode。 换言之,ReferenceEquals 方法返回 true 的两个对象具有相同的哈希代码。 如果值类型不重写 GetHashCode,基类的 ValueType.GetHashCode 方法使用反射计算基于类型字段的值的哈希代码。 换言之,字段有相同值的值类型有相等的哈希代码。
本文转自 梦在旅途 博客园博客,原文链接:
http://www.cnblogs.com/zuowj/p/4178347.html,如需转载请自行联系原作者