-
C#教程之C# 两个List<T>(T是类)使用Contains比较元素的方法
本站最新发布 C#从入门到精通
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
试听地址 https://www.xin3721.com/eschool/CSharpxin3721/
众所周知,List<T>创建的对象是引用类型,也就是说,两个完全相同的List<T>对象(其中元素及其元素的属性也相同),但引用地址不同,在使用Contains判断两List<T>中元素包含比较时,返回都是False,因此,我们需要重新“定义”Contains,实际上,Contains内部是Equals方法的封装,所以,我们需要重写Equals方法:
1 public class UserInfo : IEquatable<UserInfo> 2 { 3 public string UserName { get; set; } 4 public int Age { get; set; } 5 6 // 重写Equals方法 7 public override bool Equals(object obj) 8 { 9 if (obj == null) return false; 10 11 UserInfo usr = obj as UserInfo; 12 if (usr == null) 13 return false; 14 else 15 return Equals(usr); 16 } 17 18 // 此方法必须一起重写 19 public override int GetHashCode() 20 { 21 return UserName.GetHashCode() ^ Age.GetHashCode(); 22 } 23 24 // 实际调用的Equals方法 25 public bool Equals(UserInfo usr) 26 { 27 if (usr == null) return false; 28 return (this.UserName == usr.UserName && this.Age == usr.Age); 29 } 30 }
1 static void Main(string[] args) 2 { 3 List<UserInfo> users1 = new List<UserInfo>() 4 { 5 new UserInfo(){UserName="aaa",Age=20}, 6 new UserInfo(){UserName="bbb",Age=30}, 7 }; 8 9 List<UserInfo> users2 = new List<UserInfo>() 10 { 11 new UserInfo(){UserName="aaa",Age=20}, 12 new UserInfo(){UserName="bbb",Age=40}, 13 }; 14 15 users1.ForEach((m) => 16 { 17 if (!users2.Contains(m)) 18 Console.WriteLine($"users1中有,但users2中没有:{m.UserName},{m.Age}"); 19 }); 20 // 结果:bbb,30 21 22 users2.ForEach((m) => 23 { 24 if (!users1.Contains(m)) 25 Console.WriteLine($"users2中有,但users1中没有:{m.UserName},{m.Age}"); 26 }); 27 // 结果:bbb,40 28 29 Console.ReadKey(); 30 }
(注:进一步了解Equals和GetHashCode,请参考文章《聊一聊Equals()和GetHashCode()》: https://www.cnblogs.com/xiaochen-vip8/articles/5506478.html)
栏目列表
最新更新
C# 面向对象
假设客车的座位数是9行4列,使用二维数
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日