这里我们对LINQ中LIST
#T#
***:在.NET 1.1时,我还有很多和我一样的程序员,都会常用到ArrayList,当时要想对这种集合元素进行查找,大多会采用for循环来完成,当然也可以采用BinarySearch 方法。但自从有了.NET 2.0以及.NET 3.5后,ArrayList就已经很少使用了,大家都认为List
- public class Person
- {
- public string firstName
- { get; set; }
- public string lastName
- { get; set; }
- public int ID
- { get; set; }
- }
先构造一个Person的泛型集合。当然一般情况下不会有这样的大集合,但为了比较不同方法的搜索性能,这是有必要的。
- List
list = new List (); - for (int i = 0; i < 100001; i++)
- {
- Person p = new Person();
- p.firstName = i.ToString() + "firstName";
- p.lastName = i.ToString() + "lastName";
- list.Add(p);
- }
1:List
- public class FindPerson
- {
- public string firstName;
- public FindPerson(string _firstName)
- { this.firstName = _firstName; }
- public bool PersonPredicate(Person p)
- {
- return p.ID >= 50000;
- }
- }
- Stopwatch sw = new Stopwatch();
- sw.Start();
- List
persons = list.FindAll(new Predicate (fp.PersonPredicate)); - sw.Stop();
- Response.Write("Find方法搜索用时" + sw.ElapsedMilliseconds.ToString() + "
");
2:传统的for循环。
- sw.Start();
- List
newPersons = new List (); - for (int j = 0; j < list.Count; j++)
- {
- if (list[j].ID >= 50000)
- {
- newPersons.Add(list[j]);
- }
- }
- sw.Stop();
- Response.Write("for循环搜索用时" + sw.ElapsedMilliseconds.ToString() + "
");
3:LINQ方式查询。
- sw = new Stopwatch();
- sw.Start();
- var pn = (from m in list
- where m.ID >=50000
- select m).ToList
(); - sw.Stop();
- Response.Write("linq搜索用时" + sw.ElapsedMilliseconds.ToString() + "
");
输出结果:虽然用时差不多,但还是传统的for循环性能***,尽管写法上并无新意。FindAll我觉的有一点比较好的就是,如果针对List
Find方法搜索用时5
for循环搜索用时4
linq搜索用时6
第二:再来看对List
1:Sort。这里先写一个自定义的比较类PersonComparer
- public class PersonComparer : IComparer
- {
- public int Compare(Person x, Person y)
- {
- return x.ID.CompareTo(y.ID);
- }
- }
排序代码:
- sw = new Stopwatch();
- sw.Start();
- list.Sort(new PersonComparer());
- sw.Stop();
- Response.Write("Sort排序用时" + sw.ElapsedMilliseconds.ToString() + "
");
2:Linq方式。
- sw = new Stopwatch();
- sw.Start();
- var pn = (from m in list
- orderby m.ID descending
- select m).ToList
(); - sw.Stop();
- Response.Write("linq排序用时" + sw.ElapsedMilliseconds.ToString() + "
");
输出结果:在排序上linq还是占有比较大的优势。
Sort排序用时670
linq排序用时195
总结
对于泛型集合的操作,并不能一味的说某种方式有绝对的优势,需要根据对应的情景来选择不同的处理方式。有时候最常见的最简单的也许是性能***的。新技术当然有它的优点, Linq提供的排序在性能上就有明显的优势,但在查询方面也是最差的,尽管差距不大。
未解问题:
至于为什么for循环在查询时性能***,LINQ在排序上为什么性能好,本人并不知道其中原因,如有知道的朋友,请指教。
本文标题:对比List<T>搜索和排序中不同方法的性能
标题网址:http://www.mswzjz.cn/qtweb/news9/362259.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能