C# List对于自定义对象的比较判断
实际开发中,我们经常会把同类型的一系列对象封装到List集合中,当我们有需要在封装对象到List集合中时,排除重复的对象,这时直接使用:
if(!List.Contains(obj)) { List.Add(bj); }
在使用List对象,当T为自定义类型时,使用Contain方法将导致错误的返回结果。List.Contains(obj)比较的是:原来List集合中的对象的储存地址和当前需要添加对象obj在堆中储存的地址 ,所以即便有两个对象相等,但是它们储存的地址不同,所以List.Contains仍然返回false。下面主要使用如下两种方法来解决该问题。
1、实现 IEqualityComparer接口
public class PopupComparer : IEqualityComparer<KeyValuePair<string , double>> { public static PopupComparer Default = new PopupComparer(); #region IEqualityComparer<PopupModel> 成员 public bool Equals(KeyValuePair<string , double> x, KeyValuePair<string , double> y) { return x.Key.Equals(y.Key); } public int GetHashCode(KeyValuePair<string , double> obj) { return obj.GetHashCode(); } #endregion }
使用
if (!lt.Contains<KeyValuePair<string, double>>(kv, PopupComparer.Default)) lt.Add(kv); else Console.ReadKey();
2、重写对象的Equals和GetHashCode方法
List.Contains(obj)调用的是obj对象对应的类的Equals()方法,我们可以按需要重写这个方法和GetHashCode()方法,即可按自己的需求来定义Contains()比较方式。
public class Person { private string Number; private string personName; public Person(string name, string Number) { this.personName = name; this.Number= Number; } public bool Equals(Person p) { //按需求定制自己需要的比较方式 return (this.personName == p.personName && this.Number == p.Number); } public override int GetHashCode() { return this.Number.GetHashCode(); } } public class Example { public static void Main() { Person p1 = new Person("John", "63412895"); Person p2 = new Person("Jack", "63412895"); List<Person> List = new List<Person>(); List.Add(p1); List.Add(p2); Person p3 = new Person("John", "63412895"); if(!List.Contains(p3))//没有重写前函数返回false,现在返回true { List.Add(p3); } } }
参考文章
你们的评论、反馈,及对你们有所用,是我整理材料和博文写作的最大的鼓励和唯一动力。欢迎讨论和关注!
没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。
没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。