private static void Main(string[] args)
{
int count = ;
Console.WriteLine("判断是否存在某个元素 :");
Console.WriteLine("\t值类型比较 :");
Contains_Exists_Any_Test(count);
Console.WriteLine();
Console.WriteLine("\t引用类型比较 :");
Contains_Exists_Any_Test_Complex(count); Console.ReadKey();
} /// <summary>
/// 值类型比较
/// </summary>
/// <param name="num"></param>
public static void Contains_Exists_Any_Test(int num)
{
List<int> list = new List<int>(); int N = num;
for (int i = ; i < N; i++)
{
list.Add(i);
}
System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch();
sw.Start();
Console.WriteLine(list.Contains(N));
sw.Stop();
Console.WriteLine("Contains:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Exists(i => i == N));
sw.Stop();
Console.WriteLine("Exists:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Any(i => i == N));
sw.Stop();
Console.WriteLine("Any:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Count(i => i == N) > );
sw.Stop();
Console.WriteLine("Count:" + sw.Elapsed.ToString());
} /// <summary>
/// 引用类型比较
/// </summary>
/// <param name="num"></param>
public static void Contains_Exists_Any_Test_Complex(int num)
{
List<Person> list = new List<Person>();
Person person = new Person { Id = num };
int N = num;
for (int i = ; i < N; i++)
{
list.Add(new Person { Id = i });
}
System.Diagnostics.Stopwatch sw = new System.Diagnostics.Stopwatch();
sw.Start();
Console.WriteLine(list.Contains(person));
sw.Stop();
Console.WriteLine("Contains:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Exists(i => i.Id == person.Id));
sw.Stop();
Console.WriteLine("Exists:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Any(i => i.Id == person.Id));
sw.Stop();
Console.WriteLine("Any:" + sw.Elapsed.ToString()); sw.Reset();
sw.Start();
Console.WriteLine(list.Count(i => i.Id == person.Id) > );
sw.Stop();
Console.WriteLine("Count:" + sw.Elapsed.ToString());
}
    public class Person : IEquatable<Person>
{
public int Id { get; set; }
public string Name { get; set; }
     public int Age { get; set; } public override bool Equals(object obj)
{
//if (ReferenceEquals(null, obj))
//{
// return false;
//} //if (ReferenceEquals(this, obj))
//{
// return true;
//} //if (obj.GetType() != GetType())
//{
// return false;
//} return Equals((Person)obj);
} public bool Equals(Person other)
{
//if (ReferenceEquals(null, other))
//{
// return false;
//} //if (ReferenceEquals(this, other))
//{
// return true;
//} return Id == other.Id;
} public override int GetHashCode()
{
return Id;
}
}

结论:

值类型 : Contais > Exists > Any (Count)

引用类型 : Exists > Contains > Any (Count)

将对象需要比较的属性增加为3个:

list.Exists(i => i.Id == person.Id && i.Age == person.Age && i.Name == person.Name)
        public bool Equals(Person other)
{
//if (ReferenceEquals(null, other))
//{
// return false;
//} //if (ReferenceEquals(this, other))
//{
// return true;
//} return Id == other.Id && Age == other.Age && Name == other.Name;
}

结果:

结论跟上述一样.

Contains,Exists,Any,Count 比较是否存在某个元素的更多相关文章

  1. mysql 数据库 exists 和count

    由于最近在使用exists是出现了一个小问题,但是在调试的时候费了不少时间,因为自己只是牢固造成,所以在在此记录,已提醒自己. mysql中exists 用法: 通过和主查询管理 以达到过滤的效果,如 ...

  2. exists的用法

    今天突然看到之前自己写的一个代码 久久没想通为毛.. 看来笔记还是需要 exists可以代替子查询in  比in 更高效   默认是exists 查询中包含有数据则条件成立..否则没数据 select ...

  3. exists

    select count(*) from Table_A where exists (select count(*) from Table_B.Column1 = Table_A.Column1) 该 ...

  4. 几条sql语句(exists)

    通常exists后的子查询是需要和外面的表建立关联关系的,如 select count(*) from a where exists (select 'x' from b where a.id = b ...

  5. php count()函数用法 及其 一个坑

    用法 count() 函数返回数组中元素的数目. count(array,mode); [mode] 0 - 默认.不计算多维数组中的所有元素. 1 - 递归地计算数组中元素的数目(计算多维数组中的所 ...

  6. LINQ Count/Sum/Min/Max/Avg

    参考:http://www.cnblogs.com/peida/archive/2008/08/11/1263384.html Count/Sum/Min/Max/Avg用于统计数据,比如统计一些数据 ...

  7. 谈谈map中的count方法

    map和set两种容器的底层结构都是红黑树,所以容器中不会出现相同的元素,因此count()的结果只能为0和1,可以以此来判断键值元素是否存在(当然也可以使用find()方法判断键值是否存在). 拿m ...

  8. [转]LINQ语句之Select/Distinct和Count/Sum/Min/Max/Avg

    在讲述了LINQ,顺便说了一下Where操作,这篇开始我们继续说LINQ语句,目的让大家从语句的角度了解LINQ,LINQ包括LINQ to Objects.LINQ to DataSets.LINQ ...

  9. Linq to SQL -- Select、Distinct和Count、Sum、Min、Max、Avg

    Select/Distinct操作符 适用场景:o(∩_∩)o… 查询呗. 说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也 ...

随机推荐

  1. codevs 1492 探案第二部

    1492 探案第二部  时间限制: 1 s  空间限制: 128000 KB     题目描述 Description 我们伟大的 Sherlock·Holmes 先生最近遇上了一件相当棘手的案子,随 ...

  2. 「七天自制PHP框架」应用:JSON生成器

    刚刚开始学做一个WebAPP,数据查询的一般套路是通过一张PHP页面读取数据库,获得列表后“嵌写”在PHP页面中,虽然写法上丑陋至极,但也有“快糙猛”出效果的成就感,如图. 后来想想,不对啊,难道以后 ...

  3. Centos 7 下搭建 Dokuwiki

    Centos 7 下搭建 Dokuwiki # Dokuwiki 是php的,所以要先搭建php环境,下载 apache和php,第1.2步下载完,相关的依赖都会下载## 1.下载 httpdyum ...

  4. AJAX流程

    创建一个XHR对象 var xmlhttp; if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari ...

  5. 谈谈对Spring IOC(控制反转)的理解--转

    谈谈对Spring IOC(控制反转)的理解--转   学习过Spring框架的人一定都会听过Spring的IoC(控制反转) .DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC ...

  6. 《JavaScript 实战》:实现图片幻滑动展示效果

    滑动展示效果主要用在图片或信息的滑动展示,也可以设置一下做成简单的口风琴(Accordion)效果.这个其实就是以前写的图片滑动展示效果的改进版,那是我第一篇比较受关注的文章,是时候整理一下了. 有如 ...

  7. 说一说ASP.NET web.config 加密及解密方法 (代码)

    /// <summary> /// 保护web.config的加密和解密 /// </summary> public class ProtectHelper { /// < ...

  8. Centos tomcat jmx 远程连接

    jmx配置: -Dcom.sun.management.jmxremote-Dcom.sun.management.jmxremote.authenticate=false-Dcom.sun.mana ...

  9. 引用类型 ( 对象定义 )——Object 类型

    本文地址:http://www.cnblogs.com/veinyin/p/7607100.html  创建实例 new 操作符后跟构造函数 var people = new Object(); pe ...

  10. python初步学习-生成式、生成器、迭代器、装饰器

    生成式 列表生成式 字典生成式 集合生成式 嵌套列表生成式 列表生成式 列表生成式是python受欢迎的语法之一,通过一句简洁的语法就可以对一组元素进行过滤,还可以对得到的元素进行转换处理.语法格式为 ...