当前位置:编程学习 > asp >>

C# foreach,linq,delegate集合查询的性能比较

 

昨天和别人讨论了一下linq的性能,自我觉得linq的性能不行,但是实际上linq还是在性能上有过人之处的,linq to sql除外,以下是简单的性能测试比较代码,在这里解释一下,代码的执行速度计时测试不能用datetime了,我还是个小白,刚开始用的datetime,结果发现linq的性能并不行,但是用StopWatch才发现了事实,以前对linq的偏见的同学还是拥抱一下linq吧,也许某些方面还存在没完全理解透,还请园友们给予批评指正。

    class Program

    {

        static void Main(string[] args)

        {

            test();

        }

 

       static void test()

        {

            List<MyClass> list1 = new List<MyClass>();

            for (int i = 0; i < 10000000; i++)

            {

                MyClass aa=new MyClass();

                aa.Name = "测试数据" + i;

                aa.id = i;

                list1.Add(aa);

            }

 

            Stopwatch timer = new Stopwatch();

 

 

            #region for循环

            timer.Start();

            List<MyClass> list2 = new List<MyClass>();

 

            foreach (MyClass s in list1)

            {

                if (s.id >= 52 && s.id < 850) { list2.Add(s); }

            }

            timer.Stop();

 

            Console.Write("集合匹配数" + list2.Count + ",for循环耗时:");

            Console.WriteLine(timer.Elapsed.Ticks);

            #endregion

 

 

            #region linq

            timer = new Stopwatch();

            timer.Start();

            var list3 = list1.Where(product => product.id >= 52 && product.id < 850);

            timer.Stop();

 

 

            Console.Write("集合匹配数" + list3.Count() + ",linq耗时:");

            Console.WriteLine(timer.Elapsed.Ticks);

            #endregion

 

 

            #region delegate

            timer = new Stopwatch();

            timer.Start();

            List<MyClass> list4 = list1.FindAll(delegate(MyClass post)

            {

                return post.id >= 52 && post.id < 850;

            });

            timer.Stop();

 

            Console.Write("集合匹配数" + list4.Count() + ",delegate耗时:");

            Console.WriteLine(timer.Elapsed.Ticks);

            #endregion

 

 

            Console.Read(); 

        }

 

        public class MyClass

        {

            public string Name { get; set; }

            public int id { get; set; }

        }

    }

测试的效果截图如下:

 

\

 

如果理解的不正确,还请大家批评一下,不能让错误的思想误人子弟

 

根据园友的批评指正,重新整理了一下代码,虽然是个简单的东西,但是对于新手批评比装懂好,对园友的细心指正不胜感激。

重新整理的代码如下:

  View Code

  class Program

    {

        static void Main(string[] args)

        {

            test();

        }

 

       static void test()

        {

            List<MyClass> list1 = new List<MyClass>();

            for (int i = 0; i < 10000000; i++)

            {

                MyClass aa=new MyClass();

                aa.Name = "测试数据" + i;

                aa.id = i;

                list1.Add(aa);

            }

 

            Stopwatch timer = new Stopwatch();

 

 

            #regio

补充:Web开发 , ASP.Net ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,