用泛型的IEqualityComparer接口去重複項


寫這個源於這個網友的題問: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> 對值進行比較


 http://www.dtan.so

 一、先爲數據做個實體類: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 , 李武
     }
 }



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章