首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用泛型的IEqualityComparer<T>接口去重复项

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

作者头像
Porschev
发布2018-01-16 11:36:15
1.1K0
发布2018-01-16 11:36:15
举报

写这个源于CSDN一位网友的提问

题目:下列数据放在一个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
 }

 自定义一个比较类,去继承IEqualityComparer接口,做一个Distinct方法的比较器。。

 Equals方法中对实体进行和你需求相关的比较操作,返回bool类型的返回值

三、最后是去重复测式类:

XXXX.Distinct(new UserComparer());进行去重复操作
  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);   //输出Distinct之后的结果
         }

         Console.ReadLine();
         
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2011-11-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目:下列数据放在一个List中,当ID和Name都相同时,去掉重复数据
    • 一、先为数据做个实体类:User
      • 二、再自定义一个User比较类(实现IEqualityComparer<T>接口):UserComparer
        • 三、最后是去重复测式类:
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档