c# list排序的三種實現方式


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

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

第一種:實體類實現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         }

 

感謝xujif的提醒。


免責聲明!

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



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