2 dearwangzong dearwangzong 于 2016.03.22 20:36 提问

LINQ关于IEqualityComparer<T> 接口的问题

Linq的Distinct()方法不是说筛选数据内重复的数据吗?
原谅我只是刚学LINQ,也查阅了资料,但是我依然无法理解。
我按照书上看的,实现了一个IEqualityComparer 接口,如果真按照书上说的使用一个List的方式来做筛选的确是没问题。
于是突然想到,既然IEqualityComparer 接口是一个泛型,那么我传入一个DataRow也是可以的?
于是就写了代码
DataTable dt = new DataTable();
dt.Columns.Add("Index", typeof(int));

DataRow row = dt.NewRow();
row["Index"] = "1";
dt.Rows.Add(row);

DataRow row1 = dt.NewRow();
row1["Index"] = "2";
dt.Rows.Add(row1);

DataRow row2 = dt.NewRow();
row2["Index"] = "2";
dt.Rows.Add(row2);

RowIEqualityComparer rowEq = new RowIEqualityComparer();
var Query = dt.Rows.OfType().Distinct(rowEq);
foreach (DataRow item in Query)
{
Console.WriteLine(item["Index"].ToString());
}
Console.ReadLine();

public class RowIEqualityComparer:IEqualityComparer
{
public bool Equals(DataRow row1,DataRow row2)
{
if (row1==null&&row2==null)
{
return true;
}
if (row1==null||row2==null)
{
return false;
}
if (row1["Index"].ToString()==row2["Index"].ToString())
{
return false;
}
return true;
}

    public int GetHashCode(DataRow row) 
    {
        return row.GetHashCode();
    }
}

    程序也没有报错,按照常规来理解,这样的代码最终执行的输出结果应该是
    1
    2
    但是实际上缺输出了
    1
    2
    2
    那么这里到底是哪里有问题?是在没法查到资料

1个回答

caozhy
caozhy   Ds   Rxr 2016.03.22 23:23
已采纳
 其实用不着,最简单的是用GroupBy。
var Query = dt.Rows.OfType<DataRow>().GroupBy(x => x["Index"].ToString()).Select(x => x.First());
就可以了。
caozhy
caozhy 回复火焰猫麟: 但是没有必要定义一个类绕一个大弯子。
一年多之前 回复
caozhy
caozhy 回复火焰猫麟: 你那样写的错误在于,hashcode如果不同,对象一定不同,所以你应该return row["index"].tostring().gethashcode()
一年多之前 回复
dearwangzong
dearwangzong 谢谢,这就是我想要的结果!!谢谢层主给了我这个解答,我一晚上找了半天的答案终于得到了解答了
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!