本文的重点主要是解决:List<T>对象集合的排序功能。

一、List<T>.Sort 方法 ()

MSDN对这个无参Sort()方法的介绍:使用默认比较器对整个List<T>中的元素进行排序。

从官方文档的介绍,很难的看出详细的解析,而且还要完整的知识结构去分析,上面提到了一个关键词:比较器。大致看了下,比较器是一个委托。在这里不去透析它的完整脉络,本文只去讲解怎么去解决两个实际的问题:

  • List集合元素升序排列
  • List集合元素降序排列

1.1.对于数字类型的调用

调用结果:为升序,无法满足降序。

示例:

 1.2.对于字符串类型的调用

调用结果:把值解析成拼音字母,按照首个英文字母顺序升序排列,如果首字母相同,比较第二个的首字母。

示例:

1.3.对于自定义对象的调用

调用结果:无法完成方法的执行,运行报错。

示例:

总结:很显然这个无参的Sort()方法很难满足我们实际开发中需求,对于面向对象编程我们,常常就是对集合中的对象进行排序。


二、自定义对象类型默认排序

对象本身不是一个具体的值,在排序逻辑上显然要选择对象的一个属性进行排序。

1.1手动设置无参Sotr()方法的默认排序逻辑

将List的指定类型的类实现IComparable泛型接口,示例:

     class Student:IComparable<Student>
{ public string Id { get; set; }
public string Name { get; set; }
public int Age { get; set; } public int CompareTo(Student other)
{
//return other.Age.CompareTo(this.Age); // 年龄降序
return this.Age.CompareTo(other.Age); // 年龄升序
}
}

排序逻辑:this在前面就意味着指定按照这个属性升序,如果写在后面就是降序。

调用:

      List<Student> list_obj = new List<Student> {
new Student { Age=,Name="tom"},
new Student { Age=,Name="jack"},
new Student {Age=, Name="bob"},
}; list_obj.Sort(); for (int i = ; i < list_obj.Count; i++)
{
string output_result = string.Format("{0},年龄:{1}",list_obj[i].Name,list_obj[i].Age);
Console.WriteLine(output_result);
}

在调用Sort()方法的时候,就自动调用了我们实现接口的CompareTo方法的逻辑代码。

结果如图:

总结:此方法的实现,虽然解决了可以按照对象属性进行升序和降序,但是在实现CompareTo的方法里,指定的属性是固定的。这样的话显然

不灵活,那么下面就介绍另一种方法,解决该问题。


二、自定义对象类型动态排序

默认排序,通过实现IComparable泛型接口来完成。并且在实现ComparaTo接口里指定排序的属性是固定的,写死的。如果功能上有多条件排序(按照年龄、学号等等),默认排序就无法满足。

1.1为每一个要排序的属性写一个对应的排序类,一个排序逻辑对应一个排序类,示例:

  //按照Id升序
class StudentOrderBy_Id_asc:IComparer<Student>
{
public int Compare(Student x, Student y)
{
return x.Id.CompareTo(y.Id);
}
} //按照年龄降序
class StudentOrderBy_Age_desc:IComparer<Student>
{
public int Compare(Student x, Student y)
{
return y.Age.CompareTo(x.Age);
}
}

1.2.调用

     List<Student> list_obj = new List<Student> {
new Student { Id=,Age=,Name="tom"},
new Student { Id=,Age=,Name="jack"},
new Student {Id=,Age=, Name="bob"},
new Student {Id=,Age=, Name="ben"},
}; //---按照ID升序----
list_obj.Sort(new StudentOrderBy_Id_asc());
Console.WriteLine("---按照ID升序----");
for (int i = ; i < list_obj.Count; i++)
{
string output_result = string.Format("{0},学号:{1}",list_obj[i].Name,list_obj[i].Id);
Console.WriteLine(output_result);
}
//---END按照ID升序---- //---按照年龄降序----
list_obj.Sort(new StudentOrderBy_Age_desc());
Console.WriteLine("---按照年龄降序----");
for (int i = ; i < list_obj.Count; i++)
{
string output_result = string.Format("{0},年龄:{1}", list_obj[i].Name, list_obj[i].Age);
Console.WriteLine(output_result);
}
//---END按照年龄降序----

 1.3.输出结果:

1.4编写逻辑:

  1. 确定好要排序的属性和排序规则,为此写一个排序类。
  2. 编写Compare方法的排序逻辑(指定排序属性,排序逻辑)。
  3. 创建排序类的对象,作为参数参入,调用Sort()方法。

总结:本文主要是解决实际问题,要深入到细节原理,会涉及到一些知识点:冒泡排序、多态、比较器、委托。

   在具备知识点的前提结合Msdn文档可以尝试透析原理。

List泛型集合对象排序的更多相关文章

  1. wpf 导出Excel Wpf Button 样式 wpf简单进度条 List泛型集合对象排序 C#集合

    wpf 导出Excel   1 private void Button_Click_1(object sender, RoutedEventArgs e) 2 { 3 4 ExportDataGrid ...

  2. json字符串转泛型集合对象

    Dictionary<string, object> jd = js.Deserialize<Dictionary<string, object>>(item); ...

  3. [c#基础]泛型集合的自定义类型排序

    引用 最近总有种感觉,自己复习的进度总被项目中的问题给耽搁了,项目中遇到的问题,不总结又不行,只能将复习基础方面的东西放后再放后.一直没研究过太深奥的东西,过去一年一直在基础上打转,写代码,反编译,不 ...

  4. C#中DataTable与泛型集合互转(支持泛型集合中对象包含枚举)

    最近在做WCF,因为是内部接口,很多地方直接用的弱类型返回(DataSet),这其实是一种非常不好的方式,最近将项目做了修改,将所有接口返回值都修改成强类型,这样可以减少很多与客户端开发人员的沟通,结 ...

  5. ArrayList/List 泛型集合

    List泛型集合 集合是OOP中的一个重要概念,C#中对集合的全面支持更是该语言的精华之一. 为什么要用泛型集合? 在C# 2.0之前,主要可以通过两种方式实现集合: a.使用ArrayList 直接 ...

  6. List泛型集合常用方法

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace List ...

  7. C#基础精华03(常用类库StringBuilder,List<T>泛型集合,Dictionary<K , V> 键值对集合,装箱拆箱)

    常用类库StringBuilder StringBuilder高效的字符串操作 当大量进行字符串操作的时候,比如,很多次的字符串的拼接操作. String 对象是不可变的. 每次使用 System. ...

  8. 02.List泛型集合

    List泛型可以转换成数组 List泛型和数组的相同点: List泛型的数据类型必须是指定的,数组的数据类型也必须是指定的. List泛型和数组的不同点: List泛型的长度是随意的,而数组的长度必须 ...

  9. C# 泛型集合的自定义类型排序

    一.泛型集合List<T>排序 经sort方法之后,采用了升序的方式进行排列的. List<int> list = new List<int>() { 2, 4, ...

随机推荐

  1. 【c++】多层次继承类对象的构造函数参数的传递方法

    #include <iostream.h> //基类CBase class CBase { int a; public: CBase(int na) { a=na; cout<< ...

  2. 安装phpcms时出现Warning: ob_start(): output handler \'ob_gzhandler\' conflicts with \'zlib

    1. 解决方法一: 打开phpcms/base.php,在第57行,修改如下: if(pc_base::load_config('system','gzip') && function ...

  3. ajax.beginform控制器中实体为null的问题

    控制器: 函数声明:public JsonResult ApplyFun(Test test) 原因:在视图中有一个表单的name属性为test,因为冲突所导致.

  4. OCI 编程

    一.环境的配置 1.系统环境:要想使用OCI编程需要安装Oracle的客户端,而这个普通的客户端比较大,方便起见,可以安装即时客户端(Instantclient)作为Oracle的访问客户端.  具体 ...

  5. LFS(Linux From Scratch)学习

    一.简介 LFS──Linux from Scratch,就是一种从网上直接下载源码,从头编译LINUX的安装方式.它不是发行版,只是一个菜谱,告诉你到哪里去买菜(下载源码),怎么把这些生东西( ra ...

  6. PAT 1003 我要通过!(20)(代码+思路)

    1003 我要通过!(20)(20 分)提问 "答案正确"是自动判题系统给出的最令人欢喜的回复.本题属于PAT的"答案正确"大派送 -- 只要读入的字符串满足下 ...

  7. UI设计如何做好排版?你可以学习一下格式塔原理

    格式塔是一种视觉感知的理论,是研究人们视觉如何将元素组织成群体或整体,从而视觉上进行分类,在设计中,我们使用格式原理能使得我们设计更科学性,更具吸引力.通过格式塔效应,去处理设计中的点.线.面.颜色. ...

  8. apache的80端口被占用

    1.netstart -ano | findstr "80":查看80端口是否被占用,并找出对应的pid 2.关掉pid对应的进程

  9. 什么是tcp协议?

    这是世界上最顶尖的tcp讲解技术...

  10. 启动 nexus, major.minor 51.0 版本不支持

    a).Nexus的2.6版本及其以后版本 使用的Java的jdk7. b).Nexus的2.0-2.5版本 使用Java的jdk6的update30版本及其以后的jdk6版本 使用Java的jdk7的 ...