动态按照属性排序

  随着实体的概念的流行,DataTable正在逐渐的淡出我们的视野,但是,有些时候,DataTable很容易做的一件事情,却让我们不得不头痛起来——按指定列排序

  如果数据是来源于一个sql语句,那么,我们可以把这个问题转嫁给sql,让DB来解决这个问题。

  但是,如果数据来源于某些不支持排序(例如webservice并且没有提供排序功能),或者其他复杂情况,这样就不得不依赖于.net的集合排序。可是,如果一个系统有10个这样的类,平均每个类有10个属性可能被选择,那么就意味着有100个排序方法需要被写(c#3.0的Lambda表达式当然可以为我们省下很多力气)。如果,有一个方法直接输入属性的名称,就返回一个按照对应属性的比较器,岂不是更容易?

  基于这个想法,再加上效率的考量,用Emit写了简单的单一属性的使用默认比较器的排序:

Code

   因为,考虑到经常需要排序可空类型(例如:int?),所以,使用Comparer<T>.Default的Compare方法,当然性能上略有损失,在属性是int的情况下,与直接用Lambda相比,性能大概是5:6,也就是说在数组相对比较大时,如果用Lambda需要5s,那么用这个方法可能就需要6s。功能上来说,由于无法传入比较器,排序功能上比较弱,只能应付用属性的默认比较器的排序的情况。

原文地址:https://www.cnblogs.com/vwxyzh/p/1456320.html