C# List<T>的Contains, Exists, Any,Where性能對比


測試

新建一個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中的對象相等,它們儲存的地址也不同。感謝@餃子快跑的提醒


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM