写这个源于这个网友的题问:
题目:下列数据放在一个List中,当ID和Name都相同时,去掉重复数据
ID Name1 张三1 李三1 小伟1 李三 2 李四2 李武
------------------------------------------------------------------------------------------------------------
解决这个问题,方法很多,最开始想到的就Enumerable.Distinct方法
我们可能经常用的是
这里要用使用指定的 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 , 李武
- }
- }