用泛型的IEqualityComparer<T>接口去重复项

1 篇文章 0 订阅


写这个源于这个网友的题问: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 , 李武
     }
 }



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值