List<User> users = new List<User>();
users.Add(new User("张三", "永丰路299号"));
users.Add(new User("张三", "上地西路8号"));//重复项,去重后将删掉
users.Add(new User("李四", "海鹰路甲一号"));
第一种用字典筛选
Dictionary<string,User> dic = new
Dictionary
<string,User>();
users.ForEach(s=>{if(!dic.ContainsKey(s.name)) dic[s.name]=s;})
第二种使用
users.Where((x,i)=>users.FindIndex(s=>s.name==x.name)==i).ToList();
这条语句返回结果只保留这个List中重复的元素的第一个(name相同认为重复)
第三种 自定义去重器
public class Compare:IEqualityComparer<User>
{
public bool Equals(User x,User y)
{
return x.name == y.name;//可以自定义去重规则,此处将name相同的就作为重复记录,不管其他是什么
//return (t1.Name== t2.Name && t1.Sex== t2.Sex && t1.Age== t2.Age);
}
public int GetHashCode(User ovj)
{
return obj.name.GetHashCode();
//return t.ToString().GetHashCode();
}
}
users.Distinct(new
Compare
()).ToList();