C# - 如何为IComparable <t>类实现多个比较器?</t>

时间:2010-03-19 19:40:59

标签: c# sorting compare icomparable

我有一个实现IComparable的类。

public class MyClass : IComparable<MyClass>
{
    public int CompareTo(MyClass c)
    {
        return this.whatever.CompareTo(c.whatever);
    }

    etc..
}

然后我可以调用我的类的通用列表的排序方法

List<MyClass> c = new List<MyClass>();
//Add stuff, etc.

c.Sort();

并根据我的比较器对列表进行排序。

如何根据MyClass的其他属性指定进一步的比较器以不同的方式对我的集合进行排序,以便让用户以多种不同的方式对我的集合进行排序?

4 个答案:

答案 0 :(得分:14)

要在班级中设置排序:

public static Comparison<MyClass> OtherComparison = delegate(MyClass object1, MyClass object2)
{
    return object1.Whatever.CompareTo(object2.Whatever);
};

然后使用新的比较进行排序:

List<MyClass> myClassList = new List<MyClass>();
myClassList.Sort(MyClass.OtherComparison);

除非您明确不想对空列表进行排序:)

答案 1 :(得分:9)

您可以使用特定比较器调用Sort作为参数。参考:MSDN

答案 2 :(得分:3)

该方向的一个步骤是使用排序重载,让你指定IComparer<T>(不是IComparable<T>)。

如果您已经有很多IComparable<T>实现,那么编写IComparer<T>的通用实现来比较两个IComparable<T>实例应该是微不足道的。事实上,我有点惊讶这样一个类在BCL中已经不存在了,但是我找不到一个。

Comparer<T>.Default接近但不完全。

答案 3 :(得分:2)

如果您有多种方法对对象列表进行排序,您显然必须指定选择哪个选项。这就是Sort的其他优先事项。看看IComparer和Comparison。