【C#】List<T>的Contains, Exists, Any,Where性能对比

概念

Contains
确定某元素是否在 List 中。

参数
item T
要在 List 中定位的对象。 对于引用类型,该值可以为 null。

此方法通过使用默认相等比较器来确定相等性,该比较器由对象的方法实现 IEquatable.Equals 定义, (T 列表) 中的值类型。

此方法执行线性搜索;因此,此方法是 O (n) 操作,其中 n。Count

Exists
确定 List 是否包含与指定谓词定义的条件匹配的元素。

参数
match Predicate
Predicate 委托,用于定义要搜索的元素应满足的条件。

Predicate是方法的委托,如果传递给该方法的对象与委托中定义的条件匹配,则返回true该方法。 当前 List 元素分别传递给 Predicate 委托,找到匹配项时将停止处理。

此方法执行线性搜索;因此,此方法是 O (n) 操作,其中 n。Count

Any
确定序列中是否包含元素或存在元素满足指定条件。

参数
source IEnumerable
要检查是否为空的 IEnumerable。

此方法不返回集合中的任何一个元素, 而是确定集合中是否存在任何元素满足条件。

一旦可以确定结果,就会停止枚举 source 。

Where

基于谓词筛选值序列。

参数
source IEnumerable
要筛选的 IEnumerable。

此方法通过使用延迟执行来实现。 即时返回值是一个对象,用于存储执行操作所需的所有信息。 除非对象通过直接调用其方法或在 foreach Visual C# 或 For Each Visual Basic 中使用来枚举对象GetEnumerator,否则不会执行此方法表示的查询。

在查询表达式语法中,where (Visual C#) 或 Where (Visual Basic) 子句将转换为调用 Where(IEnumerable, Func<TSource,Boolean>)。

测试

新建一个Person类

public class Person
    {
        public Person(string name,int id)
        {
            Name = name;
            Id = id;
        }
        public string Name { get; set; }
        public int Id { get; set; }

    }

初始化List中有一百万条数据,然后分别通过每种方法判断xiaoming是否在List中,代码如下

static void Main(string[] args)
        {
            List<Person> persons = new List<Person>();
            //初始化persons数据
            for (int i = 0; i < 1000000; i++)
            {
                Person person = new Person("My" + i,i);
                persons.Add(person);
            }
            Person xiaoming=new Person("My999999", 999999);
            
            //下面通过三种方法判断persons中是否包含xiaoming
            Stopwatch watch = new Stopwatch();
            watch.Start();
            bool a = persons.Contains(xiaoming);
            watch.Stop();

            Stopwatch watch1 = new Stopwatch();
            watch1.Start();
            bool b = persons.Exists(x=>x.Id==xiaoming.Id);
            watch1.Stop();

            Stopwatch watch2 = new Stopwatch();
            watch2.Start();
            bool c = persons.Where(x=>x.Id==xiaoming.Id).Any();
            watch2.Stop();

            Stopwatch watch3 = new Stopwatch();
            watch3.Start();
            bool d = persons.Any(x => x.Id == xiaoming.Id);
            watch3.Stop();

            Console.WriteLine("Contains耗时:" + watch.Elapsed.TotalMilliseconds);
            Console.WriteLine("Exists耗时:" + watch1.Elapsed.TotalMilliseconds);
            Console.WriteLine("Where耗时:" + watch2.Elapsed.TotalMilliseconds);
            Console.WriteLine("Any耗时:" + watch3.Elapsed.TotalMilliseconds);
            Console.ReadLine();
        }

执行结果如下图所示
在这里插入图片描述

结论

通过上图可以看出性能排序为 Contains > Exists > Where > Any

注意:

上面Contains的结果为False,因为即便xiaoming和list中的对象相等,它们储存的地址也不同。

来源

C# List<T>的Contains, Exists, Any,Where性能对比
List.Contains(T) 方法
List.Exists(Predicate) 方法
Enumerable.Any 方法
Enumerable.Where 方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

软泡芙

给爷鞠躬!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值