List<T>中Exists 和Contains的区别

.net编码中,使用泛型List<>时,经常遇到这样的需求:新来一个Model对象,如果已有的List中没有这条数据,则把新对象Add到List中,否则不处理

判断已有的List中是否包含这个新的model,方法有几种,最直白的foreach遍历原有List并逐个判断

另外就是使用List自带的方法Exists 和Contains了

这两个方法有什么区别呢?通过MSDN描述和实际测试,很容易发现:

Contains方法,判断结果表示对象T的内存地址,是否在List中;

Exists方法,通过委托参数,可以指定判断对象某个值,是否与List中的某条记录的对应值相等;

显然针对开头提出的需求,用Exists方法更合适。

示例代码:

if(!MyList.Exists(t=>t.Id==MyModel.id))
{
MyList.Add(MyModel);
}

PS:实现后的思考,采用.net提供的Exists 和Contains时,和使用foreach自己遍历后比较,在内部执行效率和性能上是否有本质区别呢?

个人觉得应该是一样的,只是自己实现与采用.net封装方法的区别。

List<T>中Exists 和Contains的区别

时间: 2024-11-11 08:55:22

List<T>中Exists 和Contains的区别的相关文章

SQL语句中exists和in的区别

转自https://www.cnblogs.com/liyasong/p/sql_in_exists.html 和 http://blog.csdn.net/lick4050312/article/details/4476333 表展示 查询中涉及到的两个表,一个user和一个order表,具体表的内容如下: user表: order表: in 一.确定给定的值是否与子查询或列表中的值相匹配.in在查询的时候,首先查询子查询的表,然后将内表和外表做一个笛卡尔积,然后按照条件进行筛选.所以相对内表

Oracle中exists与in的区别

有两个简单例子,以说明 "exists"和"in"的效率问题 1) select * from T1 where exists(select 1 from T2 where T1.a=T2.a) ; T1数据量小而T2数据量非常大时,T1<<T2 时,1) 的查询效率高. 2) select * from T1 where T1.a in (select T2.a from T2) ; T1数据量非常大而T2数据量小时,T1>>T2 时,2)

oracle中exists 和 in 的区别

select * from Awhere id in(select id from B) 以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B表中的id相等,如果相等则将A表的记录加入结果集中,直到遍历完A表的所有记录.它的查询过程类似于以下过程 List resultSet=[];Array A=(select * from A);Array B=(select id from B); for(int i=0;i<A.length;i+

MySQL中exists和in的区别及使用场景

exists和in的使用方式: select * from A where exists (select * from B where A.id=B.id); select * from A where A.id in (select id from B); 1.exists是对外表做loop循环,每次loop循环再对内表(子查询)进行查询,那么是对内表的查询使用的索引,而外表有多大都需要遍历,不可避免,故内表大的使用exists,可加快效率: 2.in是把外表和内表做hash连接,先查询内表,

MySQL 中 EXISTS 的用法

在MySQL中 EXISTS 和 IN 的用法有什么关系和区别呢? 假定数据库中有两个表 分别为 表 a 和表 b create table a ( a_id int, a_name varchar(20) ) create table b ( b_id int, b_name varchar(20) ) 那么 select * from a where a_name in (select b_name from b) 这条SQL语句的意义很明显是选取满足where条件下 a 中的所有列的数据

sql中exists,not exists的用法

转 sql中exists,not exists的用法 exists : 强调的是是否返回结果集,不要求知道返回什么, 比如:  select name from student where sex = 'm' and mark exists(select 1 from grade where ...) ,只要exists引导的子句有结果集返回,那么exists这个条件就算成立了,大家注意返回的字段始终为1,如果改成"select 2 from grade where ...",那么返回

SQLServer中exists和except用法

一.exists 1.1 说明 EXISTS(包括 NOT EXISTS)子句的返回值是一个BOOL值.EXISTS内部有一个子查询语句(SELECT ... FROM...),我将其称为EXIST的内查询语句.其内查询语句返回一个结果集.EXISTS子句根据其内查询语句的结果集空或者非空,返回一个布尔值.Link exists:强调的是是否返回结果集,不要求知道返回什么,比如:select name from student where sex = 'm' and mark exists(se

DOM 中 Property 和 Attribute 的区别

原文地址:http://web.jobbole.com/83129/ property 和 attribute非常容易混淆,两个单词的中文翻译也都非常相近(property:属性,attribute:特性),但实际上,二者是不同的东西,属于不同的范畴. property是DOM中的属性,是JavaScript里的对象: attribute是HTML标签上的特性,它的值只能够是字符串: 基于JavaScript分析property 和 attribute html中有这样一段代码: <input

php学习之道:php中is_file和file_exist的区别,and判断目录is_dir

在PHP中,is_file和file_isexist是有很小区别的 1) is_file: $path ="/path/to/file/text.txt"; if(file_exists($path)) echo "File Exists"; else echo "File not Exists"; 比如在这个例子中,文件存在会返回true,不存在返回false,但注意的是,假如传入一个 正确的路径(比如一个文件目录),也会返回true: $pa