c# list排序的三種實現方式 (轉帖)


用了一段時間的gridview,對gridview實現的排序功能比較好奇,而且利用C#自帶的排序方法只能對某一個字段進行排序,今天demo了一下,總結了三種對list排序的方法,並實現動態傳遞字段名對list進行排序。

首先先介紹一下平時最常用的幾種排序方法。

第一種:實體類實現IComparable接口,而且必須實現CompareTo方法

實體類定義如下:

 

按 Ctrl+C 復制代碼
按 Ctrl+C 復制代碼

 

調用方式如下,只需要用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 }
復制代碼
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM