c# list排序的三种实现方式

转载 2013年12月01日 20:40:56

c# list排序的三种实现方式

用了一段时间的gridview,对gridview实现的排序功能比较好奇,而且利用C#自带的排序方法只能对某一个字段进行排序,今天demo了一下,总结了三种对list排序的方法,并实现动态传递字段名对list进行排序。

首先先介绍一下平时最常用的几种排序方法。

第一种:实体类实现IComparable接口,而且必须实现CompareTo方法

实体类定义如下:

 

复制代码
 1 class Info:IComparable
 2     {
 3         public int Id { get; set; }
 4         public string Name { get; set; }
 5 
 6         public int CompareTo(object obj) {
 7             int result;
 8             try
 9             {
10                 Info info = obj as Info;
11                 if (this.Id > info.Id)
12                 {
13                     result = 0;
14                 }
15                 else
16                     result = 1;
17                 return result;
18             }
19             catch (Exception ex) { throw new Exception(ex.Message); }
20         }
21     }
复制代码

 

调用方式如下,只需要用sort方法就能实现对list进行排序。

 

复制代码
 1 private static void ReadAccordingCompare() {
 2             List<Info> infoList = new List<Info>();
 3             infoList.Add(
 4                 new Info() { Id = 1, Name = "abc" });
 5             infoList.Add(new Info() { Id = 3, Name = "rose" });
 6             infoList.Add(new Info() { Id = 2, Name = "woft" });
 7                infoList.Sort();
 8             foreach (var item in infoList)
 9             {
10                 Console.WriteLine(item.Id + ":" + item.Name); 
11             }
12         }
复制代码

 

第二种方法:linq to list进行排序

运用linq实现对list排序,在实体类定义的时候就不需用实现IComparable接口,调用方式如下:

复制代码
 1 private static void ReadT(string str) {
 2             List<Info> infoList = new List<Info>();
 3             infoList.Add(
 4                 new Info() { Id = 1, Name = "woft" });
 5             infoList.Add(new Info() { Id=3,Name="rose"});
 6             infoList.Add(new Info() { Id = 2, Name = "abc" });
 7             Console.WriteLine("ReadT*********************");
 8             IEnumerable<Info> query = null;
 9             query = from items in infoList orderby items.Id select items;
10             foreach (var item in query)
11             {
12                 Console.WriteLine(item.Id+":"+item.Name);
13             }
14         }
复制代码

但是上面两种方式都只能对一个实体属性排序,如果对不同的属性排序的话只能写很多的if进行判断,这样显得很麻烦。

且看下面的方式实现根据传入参数进行排序。

 

复制代码
 1 private static void ListSort(string field,string rule)
 2         {
 3             if (!string.IsNullOrEmpty(rule)&&(!rule.ToLower().Equals("desc")||!rule.ToLower().Equals("asc")))
 4             {
 5                 try
 6                 {
 7                     List<Info> infoList = GetList();
 8                     infoList.Sort(
 9                         delegate(Info info1, Info info2)
10                         {
11                             Type t1 = info1.GetType();
12                             Type t2 = info2.GetType();
13                             PropertyInfo pro1 = t1.GetProperty(field);
14                             PropertyInfo pro2 = t2.GetProperty(field);
15                             return rule.ToLower().Equals("asc") ?
16                                 pro1.GetValue(info1, null).ToString().CompareTo(pro2.GetValue(info2, null).ToString()) :
17                                 pro2.GetValue(info2, null).ToString().CompareTo(pro1.GetValue(info1, null).ToString());
18                         });
19                     Console.WriteLine("*****ListSort**********");
20                     foreach (var item in infoList)
21                     {
22                         Console.WriteLine(item.Id + "," + item.Name);
23                     }
24                 }
25                 catch (Exception ex)
26                 {
27                     Console.WriteLine(ex.Message);
28                 }
29             } Console.WriteLine("ruls is wrong");
30 
31         }
复制代码

 

调用方式:

复制代码
ListSort("Name","desc");//表示对Name进行desc排序
ListSort("Id","asc");//表示对Id进行asc排序。如此如果参数很多的话减少了很多判断。
复制代码

 

如果有更好的方法欢迎提出,共同学习………..

后续:受一位留言着的提醒,在用反射实现多字段排序时只需一次反射,多余的一次放而会影响性能,现更新如下:

复制代码
 1 private static void ListSort(string field,string rule)
 2         {
 3             if (!string.IsNullOrEmpty(rule) && (rule.ToLower().Equals("desc") || rule.ToLower().Equals("asc")))
 4             {
 5                 try
 6                 {
 7                     List<Info> infoList = GetList();
 8                     infoList.Sort(
 9                         delegate(Info info1, Info info2)
10                         {
11                             Type t = typeof(Info);
12                             PropertyInfo pro = t.GetProperty(field);
13                             return rule.ToLower().Equals("asc") ?
14                                 pro.GetValue(info1, null).ToString().CompareTo(pro.GetValue(info2, null).ToString()) :
15                                 pro.GetValue(info2, null).ToString().CompareTo(pro.GetValue(info1, null).ToString());
16                         });
17                     Console.WriteLine("*****ListSort**********");
18                     foreach (var item in infoList)
19                     {
20                         Console.WriteLine(item.Id + "," + item.Name);
21                     }
22                 }
23                 catch (Exception ex)
24                 {
25                     Console.WriteLine(ex.Message);
26                 }
27             }
28             else
29                 Console.WriteLine("ruls is wrong");
30         }
复制代码

 

感谢xujif的提醒

转自 http://www.cnblogs.com/bradwarden/archive/2012/06/19/2554854.html



c# list排序的三种实现方式

摘自:http://www.cnblogs.com/bradwarden/archive/2012/06/19/2554854.html 用了一段时间的gridview,对gridview实现的排序...
  • qq_31971935
  • qq_31971935
  • 2016年07月21日 10:41
  • 128

c# list排序的三种实现方式

用了一段时间的gridview,对gridview实现的排序功能比较好奇,而且利用C#自带的排序方法只能对某一个字段进行排序,今天demo了一下,总结了三种对list排序的方法,并实现动态传递字段名对...
  • yanfeng918
  • yanfeng918
  • 2014年09月04日 14:10
  • 192

c# list排序的三种实现方式

原文地址:http://www.cnblogs.com/bradwarden/archive/2012/06/19/2554854.html 第一种:实体类实现IComparable接口,而且必...
  • cxcalm
  • cxcalm
  • 2015年08月13日 16:19
  • 273

c# list排序的三种实现方式

用了一段时间的gridview,对gridview实现的排序功能比较好奇,而且利用C#自带的排序方法只能对某一个字段进行排序,今天demo了一下,总结了三种对list排序的方法,并实现动态传递字段名对...
  • fengsuifeng___
  • fengsuifeng___
  • 2016年03月19日 15:36
  • 156

c# list排序的三种实现方式

在这里主要是应用于fineui绑定List数据的方法,本来是List转Dataset 后来觉得太麻烦了。 用了一段时间的gridview,对gridview实现的排序功能比较好奇,而且利用C#自...
  • mofijeck
  • mofijeck
  • 2014年12月03日 09:20
  • 233

c# list排序的三种实现方式

用了一段时间的gridview,对gridview实现的排序功能比较好奇,而且利用C#自带的排序方法只能对某一个字段进行排序,今天demo了一下,总结了三种对list排序的方法,并实现动态传递字段名对...
  • qq373591361
  • qq373591361
  • 2014年03月13日 14:25
  • 361

几种常用排序方法的C#实现

详见:http://student.zjzk.cn/course_ware/data_structure/web/paixu/paixu8.3.1.1.htm 在网上搜罗了一下,各种排序方法的实现...
  • AnYuanLzh
  • AnYuanLzh
  • 2013年08月07日 02:07
  • 1264

用C#实现对数组元素排序(冒泡法)

昨天学习了如何用Split方法对数组进行处理,还学习了如何用Array.Sort()方法对数组进行排序,今天来研究下冒泡算法 冒泡算法(Bubble Sort)先画表来说明下: 比如说,我们有个八位...
  • qq_21018935
  • qq_21018935
  • 2016年11月09日 16:31
  • 1749

Java实现三种排序算法

学习Java有一段时间了,今天研究了一下简单的算法,算法确实非常难,yonglebantiandeshijiancaino...
  • u014740732
  • u014740732
  • 2014年09月22日 16:26
  • 819

list排序的三种实现方式

第一种:实体类实现IComparable接口,而且必须实现CompareTo方法 实体类定义如下:class Info:IComparable { public in...
  • u011948354
  • u011948354
  • 2015年01月20日 09:03
  • 211
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c# list排序的三种实现方式
举报原因:
原因补充:

(最多只允许输入30个字)