C# list排序的三种实现方法

原文地址:http://www.cnblogs.com/bradwarden/archive/2012/06/19/2554854.html

 

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

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

实体类定义如下:

 

View Code
 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进行排序。

 

View Code
 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接口,调用方式如下:

View Code
 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进行判断,这样显得很麻烦。

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

 

View Code
 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排序。如此如果参数很多的话减少了很多判断。

 

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

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

View Code
 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 }

 

 

转载于:https://www.cnblogs.com/caolin/p/4475647.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值