寫這個源於這個網友的題問:http://topic.csdn.net/u/20110803/16/031363d0-831d-4795-8c29-458d1271cc83.html?48229
題目:下列數據放在一個List中,當ID和Name都相同時,去掉重複數據
ID Name
1 張三
1 李三
1 小偉
1 李三
2 李四
2 李武
------------------------------------------------------------------------------------------------------------
解決這個問題,方法很多,最開始想到的就Enumerable.Distinct方法
我們可能經常用的是Distinct<TSource>(IEnumerable<TSource>)
這裏要用Distinct<TSource>(IEnumerable<TSource>, IEqualityComparer<TSource>) 使用指定的 IEqualityComparer<T> 對值進行比較
一、先爲數據做個實體類:User
public class User
{
public User(int id, string name)
{
Id = id;
Name = name;
}
public int Id { get; set; }
public string Name { get; set; }
}
二、再自定義一個User比較類(實現IEqualityComparer<T>接口):UserComparer
public class UserComparer : IEqualityComparer<User>
{
#region IEqualityComparer<User> 成員
public bool Equals(User x, User y)
{
if (x.Id == y.Id && x.Name == y.Name)
return true;
else
return false;
}
public int GetHashCode(User obj)
{
return 0;
}
#endregion
}
三、最後是去重複測式類:
public class MainClass
{
public static void Main()
{
List<User> list = new List<User>();
list.Add(new User(1, "張三"));
list.Add(new User(1, "李三"));
list.Add(new User(1, "小偉"));
list.Add(new User(1, "李三"));
list.Add(new User(2, "李四"));
list.Add(new User(2, "李武"));
var query = list.Distinct(new UserComparer());
foreach (var item in query)
{
Console.WriteLine(item.Id + "," + item.Name);
}
Console.ReadLine();
//輸出結果:
// 1 , 張三
// 1 , 李三
// 1 , 小偉
// 2 , 李四
// 2 , 李武
}
}