文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

List<T>搜索和排序中的方法有什么不不同

2023-06-17 17:15

关注

本篇内容介绍了“List<T>搜索和排序中的方法有什么不不同”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

在.NET 1.1时,我还有很多和我一样的程序员,都会常用到ArrayList,当时要想对这种集合元素进行查找,大多会采用for循环来完成,当然也可以采用BinarySearch 方法。但自从有了.NET 2.0以及.NET 3.5后,ArrayList就已经很少使用了,大家都认为List<T>在性能上要优越于ArrayList。既然有了List<T>,有了LINQ,对于LIST<T>集合的查询就不再单一。我这里列举三种方法:它们共同完成一件事,在一个Person的集合中,查找编号大于50000的元素。Person类定义如下:

public class Person  {      public string firstName      { get; set; }      public string lastName      { get; set; }      public int ID      { get; set; }  }

先构造一个Person的泛型集合。当然一般情况下不会有这样的大集合,但为了比较不同方法的搜索性能,这是有必要的。

List<Person> list = new List<Person>();  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<T>提供的FindAll方式。  

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<Person> persons = list.FindAll(new Predicate<Person>(fp.PersonPredicate));  sw.Stop();  Response.Write("Find方法搜索用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");

2:传统的for循环。 

sw.Start();  List<Person> newPersons = new List<Person>();  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() + "<br/>");

3:LINQ方式查询。 

sw = new Stopwatch();  sw.Start();  var pn = (from m in list            where m.ID >=50000            select m).ToList <Person >();  sw.Stop();  Response.Write("linq搜索用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");

输出结果:虽然用时差不多,但还是传统的for循环性能***,尽管写法上并无新意。FindAll我觉的有一点比较好的就是,如果针对List<Person>有很多种查询方式,(当然实际情况中Person类不会这么简单),把查询方式封闭在FindPerson类中比较好,这样在外部调用查询时会非常简单。如果是其它的方式,也可以封装,但明显在代码结构上要稍差。Linq方式的查询,在灵活性上我觉的比起前两种要差一些。

Find方法搜索用时5

for循环搜索用时4

linq搜索用时6

第二:再来看对List<T>的排序,这里比较List<T>提供的Sort方法和Linq方式的orderby。

Sort。这里先写一个自定义的比较类PersonComparer

public class PersonComparer : IComparer<Person>  {      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() + "<br/>");

Linq方式。

sw = new Stopwatch();  sw.Start();  var pn = (from m in list           orderby m.ID descending            select m).ToList<Person>();  sw.Stop();  Response.Write("linq排序用时" + sw.ElapsedMilliseconds.ToString() + "<br/>");

输出结果:在排序上linq还是占有比较大的优势。

Sort排序用时670

linq排序用时195

“List<T>搜索和排序中的方法有什么不不同”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯