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. HDU 4978 计算 凸包

    有以无限间隔$D$的水平线分割的平面,在上面随机投下一个圆,圆中有一些点,点之间两两成一条线段,问随机投下至少有一条线段于平行线相交的概率. 以下是不严(luan)谨(lai)的思路. 首先都知道对于 ...

  2. POJ3061 Subsequence 尺取or二分

    Description A sequence of N positive integers (10 < N < 100 000), each of them less than or eq ...

  3. 编程笔记:JavaScript 中的类型检查

    在Badoo的时候我们写了大量的JS脚本,光是在我们的移动web客户端上面就有大概60000行,可想而知,维护这么多JS可是相当具有挑战性的.在写如上规模js脚本客户端应用的时候我们必须对一件事保持警 ...

  4. 多进程Process

    多进程旧式写法 from multiprocessing import Pool def f(x): return x*x if __name__ == '__main__': p = Pool(5) ...

  5. 执行impdp时出现的各种问题

    1.不同的表空间,不同的用户,不同的表名 impdp ODS_YYJC_BUF_ZB/ODS_YYJC_BUF_ZB job_name=bs3 directory=EXPDMP exclude=OBJ ...

  6. 看到了一篇博文,关于网卡的sniff模式,感觉相当好

    @font-face { font-family: "Times New Roman"; }@font-face { font-family: "宋体"; }@ ...

  7. perl6正则 1: ~~ , //, m//, rx//

    ~~ perl6 中, 要匹配一个正则, 使用 ~~ 智能匹配符. > so 'abcde' ~~ /a.c/ True > so 'abcde' ~~ /a.d/ False > ...

  8. sqlite3在Linux下的安装和使用

    自我补充:ubuntu在线安装sqlite3数据库的方法:  系统平台:ubuntu12.04   在ubuntu里面直接使用命令:sudo apt-get install sqlite3 ,出现: ...

  9. ubuntu的su初始密码设置

    Ubuntu刚安装后,不能在terminal中运行su命令,因为root没有默认密码,需要手动设定. 以安装ubuntu时输入的用户名登陆,该用户在admin组中,有权限给root设定密码. 给roo ...

  10. logging模块配置笔记

    logging模块配置笔记 log文件的路径 #判断在当前的目录下是否有一个logs文件夹.没有则创建 log_dir = os.path.dirname(os.path.dirname(__file ...