c# list排序的三种实现方式 (转帖)
用了一段時(shí)間的gridview,對(duì)gridview實(shí)現(xiàn)的排序功能比較好奇,而且利用C#自帶的排序方法只能對(duì)某一個(gè)字段進(jìn)行排序,今天demo了一下,總結(jié)了三種對(duì)list排序的方法,并實(shí)現(xiàn)動(dòng)態(tài)傳遞字段名對(duì)list進(jìn)行排序。
首先先介紹一下平時(shí)最常用的幾種排序方法。
第一種:實(shí)體類實(shí)現(xiàn)IComparable接口,而且必須實(shí)現(xiàn)CompareTo方法
實(shí)體類定義如下:
?
按 Ctrl+C 復(fù)制代碼 class Info:IComparable { public int Id { get; set; } public string Name { get; set; } public int CompareTo(object obj) { int result; try { Info info = obj as Info; if (this.Id > info.Id) { result = 0; } else result = 1; return result; } catch (Exception ex) { throw new Exception(ex.Message); } } }按 Ctrl+C 復(fù)制代碼?
調(diào)用方式如下,只需要用sort方法就能實(shí)現(xiàn)對(duì)list進(jìn)行排序。
?
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進(jìn)行排序
運(yùn)用linq實(shí)現(xiàn)對(duì)list排序,在實(shí)體類定義的時(shí)候就不需用實(shí)現(xiàn)IComparable接口,調(diào)用方式如下:
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 }但是上面兩種方式都只能對(duì)一個(gè)實(shí)體屬性排序,如果對(duì)不同的屬性排序的話只能寫很多的if進(jìn)行判斷,這樣顯得很麻煩。
且看下面的方式實(shí)現(xiàn)根據(jù)傳入?yún)?shù)進(jìn)行排序。
?
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 }?
調(diào)用方式:
ListSort("Name","desc");//表示對(duì)Name進(jìn)行desc排序 ListSort("Id","asc");//表示對(duì)Id進(jìn)行asc排序。如此如果參數(shù)很多的話減少了很多判斷。?
如果有更好的方法歡迎提出,共同學(xué)習(xí)………..
后續(xù):受一位留言著的提醒,在用反射實(shí)現(xiàn)多字段排序時(shí)只需一次反射,多余的一次放而會(huì)影響性能,現(xiàn)更新如下:
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 }轉(zhuǎn)載于:https://www.cnblogs.com/xihong2014/p/4166352.html
總結(jié)
以上是生活随笔為你收集整理的c# list排序的三种实现方式 (转帖)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 给GridView删除列添加删除提示
- 下一篇: 网络游戏服务器端架构设计(转载)