c# list排序的三种实现方式
来源:互联网 发布:做淘宝外网站赚钱吗 编辑:程序博客网 时间:2024/05/31 05:27
c# 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 else16 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 else29 Console.WriteLine("ruls is wrong");30 }
感谢xujif的提醒
转自 http://www.cnblogs.com/bradwarden/archive/2012/06/19/2554854.html
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- c# list排序的三种实现方式
- list排序的三种实现方式
- list排序的三种实现方式
- Repeater排序的三种实现方式
- C#接口的三种实现方式
- C#实现的三种方式实现模拟键盘按键
- 快速排序的三种不同的实现方式。
- python实现堆排序的三种方式
- php二维数组排序的三种实现方式
- 数据结构-快速排序的三种实现方式及其优化
- C#实现启用、禁用本地网络的三种方式
- C#三种WCF网络客户端的实现方式
- WERTYU
- 如何伪装zip文件
- LeetCode Search in Rotated Sorted Array 在旋转了的数组中查找
- 静态构造函数
- UNIX下C语言的图形编程-curses.h函数库
- c# list排序的三种实现方式
- 记录
- 设计模式学习笔记——面向对象设计原则
- qsort.c源代码分析
- ios开发(十): 全局变量的定义和使用
- C++虚函数
- 利用busybox制作根文件系统
- java synchronized详解
- HDU4252:A Famous City