最新更新 sitemap 网站制作设计本站搜索
网页设计
国外网站 韩国网站 个人主页 手提袋设计 CSS 网页特效 平面设计 网站设计 Flash CMS技巧 服装网站 php教程 photoshop 画册 服务器选用 数据库 Office
虚拟主机 域名注册 云主机 网页设计 客服QQ:8208442
当前位置:首页 > 编程开发 > asp教程

List采用不同方法的性能比较

日期:02-11    来源:中国设计秀    作者:cnwebshow.com

  第一:在.net1.1时,我还有很多和我一样的程序员,都会常用到ArrayList,当时要想对这种集合元素进行查找,大多会采用for循环来完成,当然也可以采用BinarySearch 方法。但自从有了.net2.0以及.net3.5后,ArrayList就已经很少使用了,大家都认为List<T>在性能上要优越于ArrayList。既然有了List<T>,有了LINQ,对于LIST<T>集合的查询就不再单一。我这里列举三种方法:它们共同完成一件事,在一个Person的集合中,查找编号大于50000的元素。xbe中国设计秀
xbe中国设计秀
      Person类定义如下:xbe中国设计秀
xbe中国设计秀
    public class Personxbe中国设计秀
    {xbe中国设计秀
        public string firstNamexbe中国设计秀
        { get; set; }xbe中国设计秀
        public string lastNamexbe中国设计秀
        { get; set; }xbe中国设计秀
        public int IDxbe中国设计秀
        { get; set; }xbe中国设计秀
    }xbe中国设计秀
xbe中国设计秀
       xbe中国设计秀
xbe中国设计秀
      先构造一个Person的泛型集合。当然一般情况下不会有这样的大集合,但为了比较不同方法的搜索性能,这是有必要的。xbe中国设计秀
   xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
            List<Person> list = new List<Person>();xbe中国设计秀
            for (int i = 0; i < 100001; i++)xbe中国设计秀
            {xbe中国设计秀
                Person p = new Person();xbe中国设计秀
                p.firstName = i.ToString() + "firstName";xbe中国设计秀
                p.lastName = i.ToString() + "lastName";xbe中国设计秀
                p.ID = i;xbe中国设计秀
                list.Add(p);xbe中国设计秀
xbe中国设计秀
            }xbe中国设计秀
xbe中国设计秀
       1:List<T>提供的FindAll方式。xbe中国设计秀
    xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
    public class FindPersonxbe中国设计秀
    {xbe中国设计秀
        public string firstName;xbe中国设计秀
        public FindPerson(string _firstName)xbe中国设计秀
        { this.firstName = _firstName; }xbe中国设计秀
        public bool PersonPRedicate(Person p)xbe中国设计秀
        {xbe中国设计秀
            return p.ID >= 50000;xbe中国设计秀
        }xbe中国设计秀
    }xbe中国设计秀
    Stopwatch sw = new Stopwatch();xbe中国设计秀
    sw.Start();xbe中国设计秀
    List<Person> persons = list.FindAll(new Predicate<Person>(fp.PersonPredicate));xbe中国设计秀
    sw.Stop();xbe中国设计秀
    Response.Write("Find方法搜索用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");xbe中国设计秀
xbe中国设计秀
       2:传统的for循环。xbe中国设计秀
   xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
            sw.Start();xbe中国设计秀
            List<Person> newPersons = new List<Person>();xbe中国设计秀
            for (int j = 0; j < list.Count; j++)xbe中国设计秀
            {xbe中国设计秀
                if (list[j].ID  >= 50000)xbe中国设计秀
                {xbe中国设计秀
                    newPersons.Add(list[j]);xbe中国设计秀
xbe中国设计秀
                }xbe中国设计秀
            }xbe中国设计秀
            sw.Stop();xbe中国设计秀
            Response.Write("for循环搜索用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");xbe中国设计秀
xbe中国设计秀
  xbe中国设计秀
xbe中国设计秀
      3:LINQ方式查询。xbe中国设计秀
   xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
            sw = new Stopwatch();xbe中国设计秀
            sw.Start();xbe中国设计秀
            var pn = (from m in listxbe中国设计秀
                      where m.ID >=50000xbe中国设计秀
                      select m).ToList <Person >();xbe中国设计秀
            sw.Stop();xbe中国设计秀
            Response.Write("linq搜索用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");xbe中国设计秀
xbe中国设计秀
xbe中国设计秀
xbe中国设计秀
     输出结果:虽然用时差不多,但还是传统的for循环性能最佳,尽管写法上并无新意。FindAll我觉的有一点比较好的就是,如果针对List<Person>有很多种查询方式,(当然实际情况中Person类不会这么简单),把查询方式封闭在FindPerson类中比较好,这样在外部调用查询时会非常简单。如果是其它的方式,也可以封装,但明显在代码结构上要稍差。Linq方式的查询,在灵活性上我觉的比起前两种要差一些。xbe中国设计秀
xbe中国设计秀
     Find方法搜索用时5xbe中国设计秀
     for循环搜索用时4xbe中国设计秀
     linq搜索用时6xbe中国设计秀
xbe中国设计秀
     第二:再来看对List<T>的排序,这里比较List<T>提供的Sort方法和Linq方式的orderby。xbe中国设计秀
xbe中国设计秀
     1:Sort。这里先写一个自定义的比较类PersonComparerxbe中国设计秀
    xbe中国设计秀
xbe中国设计秀
    public class PersonComparer : IComparer<Person>xbe中国设计秀
    {xbe中国设计秀
        public int Compare(Person x, Person y)xbe中国设计秀
        {xbe中国设计秀
            return x.ID.CompareTo(y.ID);xbe中国设计秀
        }xbe中国设计秀
    xbe中国设计秀
    }xbe中国设计秀
xbe中国设计秀
    排序代码:xbe中国设计秀
    xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
            sw = new Stopwatch();xbe中国设计秀
            sw.Start();xbe中国设计秀
            list.Sort(new PersonComparer());xbe中国设计秀
            sw.Stop();xbe中国设计秀
            Response.Write("Sort排序用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");xbe中国设计秀
   xbe中国设计秀
      2:Linq方式。xbe中国设计秀
    xbe中国设计秀
xbe中国设计秀
代码 xbe中国设计秀
            sw = new Stopwatch();xbe中国设计秀
            sw.Start();xbe中国设计秀
            var pn = (from m in listxbe中国设计秀
                     orderby m.ID descendingxbe中国设计秀
                      select m).ToList<Person>();xbe中国设计秀
            sw.Stop();xbe中国设计秀
            Response.Write("linq排序用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");xbe中国设计秀
xbe中国设计秀
    xbe中国设计秀
xbe中国设计秀
      输出结果:在排序上linq还是占有比较大的优势。xbe中国设计秀
      Sort排序用时670xbe中国设计秀
      linq排序用时195xbe中国设计秀
xbe中国设计秀
     总结:对于泛型集合的操作,并不能一味的说某种方式有绝对的优势,需要根据对应的情景来选择不同的处理方式。有时候最常见的最简单的也许是性能最好的。新技术当然有它的优点, Linq提供的排序在性能上就有明显的优势,但在查询方面也是最差的,尽管差距不大。xbe中国设计秀
xbe中国设计秀
 xbe中国设计秀

本文引用地址:/bc/article_46118.html
网站地图 | 关于我们 | 联系我们 | 网站建设 | 广告服务 | 版权声明 | 免责声明