C#中的集合类常常需要排序,集合类的Sort方法是常用方法。
比如 List<T> list=...,需要对list进行排序,可以用list.Sort()方法。该方法有多个重载。
(1) IComparable<in T>接口
即 public interface IComparable<in T>
{
int CompareTo(T other);
}
当某对象实现了该接口,则表示该对象是可排序的。
(2)IComparer<T>接口
表示排序器。对于没有实现Comparable<T>接口的对象,可以为其创建实现IComparer<T>接口的排序器,用于排序。录入,可以为Sort传入IComparer<T>的实现类的实例对象,该接口为:
public interface IComparer<in T>
{
//如果x小于y,则返回负数;x大于y,返回正数;等于则返回0
int Compare(T x, T y);
}
void Sort(IComparer<T> comparison);
如果使用IComparer<T>实现类的实例对象,则需要实现定义好实现类,对于已经定义好的,则比较方便,否则相对麻烦一些。
(3)Comparison<T>委托
但是对于没有定义IComparer<T>的实现类的场合,可以使用更为方便的方式,即使用Comparison<T>委托作为参数。
public delegate int Comparison<in T>(T x, T y);
void Sort(Comparison<T> comparison);
具体使用时,可以直接传入委托(或函数名称),也可以直接使用numda表达式。以下是使用numda表达式的方法代码:
List<Student> list=new List<Student>(); //Student类中含有Age属性
list.AddRange(....); //添加数据
//以下对Student集合按照其Age属性从小到大排序
list.Sort( (x, y) =>
{
if (x.Age < y.Age)
{
return -1;
}
else if (x.Age > y.Age)
{
return 1;
}
else
return 0;
}
);
或者以下更加简单的写法********:
list.sort((x,y)=>x.Age.CompareTo(y.Age));