C# List.Sort四种重载总结

 更新时间:2025年12月01日 15:31:42   作者:红黑色的圣西罗  
本文详细分析了C#中List.Sort()方法的四种重载形式及其实现原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在实现工作中的系统功能时,总是会出现对数据排序的需求,而排序算法在C#中有提前封装好的方法,即List.Sort

1. Sort方法的四种重载

在List中

可以看到,分别为

List<T>.Sort();   
List<T>.Sort(IComparer<T> Comparer);
List<T>.Sort(int index, int count, IComparer<T> Comparer);
List<T>.Sort(Comparison<T> comparison);

其中,第一,第二两个方法内部其实都是在调用第三个方法,只不过参数传的不一样。

第三个方法的index参数表示从哪个索引开始,count表示要排序的个数,comparer表示实现了IComparer接口的类型,用于实现排序规则,可以看到前两个方法都是从头开始全量排序。
最终调用的都是Array.Sort()方法

2. 具体使用

- List.Sort();

可以看到对于int类型默认是实现升序排序的,对于bool类型,false会排在true前面

那如果是一个复杂类型呢?

可以看到,传的是一个Demo类型的对象,但是直接使用Sort方法会报错,提示“未能比较数组中的两个元素,必须至少有一个对象实现IComparable”

那么为什么会报这个错呢,深入源码来看,从调用堆栈看应该是走到了这一步,在Array中

继续深入,来到ArraySortHelper类

注意此时的comparer因为是null,所以给了一个Comparer.Default

最终来到了

然后在调用comparer.Compare方法时报错

深入Comparer类,查看Default

即最终调用的是ObjectComparer.Compare方法

进行最终深入,来到Comparer类的Compare方法

首先会判断m_compareInfo是否为空,那么看上面

可以看到,虽然Default会传入一个compareInfo,但是因为传入的对象类型在强制类型转换为string后其实是null,所以会进行下面的判断。

即比较的最终执行是判断比较的两个对象是否实现了IComparable接口,而传入的Demo类型并没有实现这个接口,所以最终报错

- IComparable 接口

按照上面探索的结果,直接使用Sort方法最终会判断传入类型是否实现了IComparable 接口,那么int类型和bool类型能够直接使用说明两者实现了IComparable 接口

先看int类型

可以看到int实现了IComparable 的CompareTo方法,规则为小于返回-1,大于返回1,等于返回0,说明此时返回-1是升序,返回1是降序

再看bool类型

规则为等于返回0,如果自身为false返回-1,如果自身为true,返回1

再回到

可以看到,当comparer.Compare返回大于0时,会将比较的双方进行交换,所以int类型和bool类型的最终结果显而易见,即大的数和true会被交换到后面

对于string类型,其也实现了IComparable 接口,但字符串的比较是通过比较每一个字符的Unicode 编码大小,这里不再赘述

- 复杂类型的比较

综上所述,如果需要比较一个复杂的类型,那么必须实现IComparable 接口

比如这里的Demo类型,实现了自定义的比较方法,先比较name,再比较age

或者,使用List.Sort(IComparer Comparer),即需要实现IComparer接口,定义一个比较器

DemoComparer实现了IComparer接口,在内部实现了自定义的Demo类型的比较

- List.Sort(Comparison comparison)

或者

可以看到这里会使用Array的方法,将comparison转换为IComparer的比较器

最终调用的就是传入的Comparison委托

到此这篇关于C# List.Sort四种重载总结的文章就介绍到这了,更多相关C# List.Sort重载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Unity UGUI的Outline描边组件的介绍使用示例

    Unity UGUI的Outline描边组件的介绍使用示例

    这篇文章主要介绍了Unity UGUI的Outline描边组件的介绍使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • 解析C#设计模式之单例模式

    解析C#设计模式之单例模式

    这篇文章主要介绍了C#设计模式之单例模式的相关资料,帮助大家更好的理解和学习c# 设计模式的内容,感兴趣的朋友可以了解下
    2020-12-12
  • C#实现MQTT服务端与客户端通讯功能

    C#实现MQTT服务端与客户端通讯功能

    这篇文章介绍了C#实现MQTT服务端与客户端通讯的功能,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • 解决winform界面刷新闪烁问题的多种方案

    解决winform界面刷新闪烁问题的多种方案

    这篇文章给大家介绍了如何解决winform界面刷新闪烁问题的多种方案,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-02-02
  • 详解C#中的session用法

    详解C#中的session用法

    这篇文章主要介绍了C#中的session用法 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • C#回收机制之资源回收托管

    C#回收机制之资源回收托管

    这篇文章介绍了C#回收机制之资源回收托管,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • C#调用新浪微博API实例代码

    C#调用新浪微博API实例代码

    在本篇文章里小编给大家整理的是一篇关于C#调用微博API的相关知识点内容,有需要的朋友们可以学习下。
    2019-11-11
  • C#实现文件操作(复制,移动,删除)的方法详解

    C#实现文件操作(复制,移动,删除)的方法详解

    File类提供了常见的文件操作函数,包括复制、移动、删除、创建快捷方式等,本文将通过一些简单的示例为大家详细讲讲具体的使用,希望对大家有所帮助
    2023-05-05
  • C#计算矩阵的逆矩阵方法实例分析

    C#计算矩阵的逆矩阵方法实例分析

    这篇文章主要介绍了C#计算矩阵的逆矩阵方法,较为详细的分析了逆矩阵的计算原理与相关的C#实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • C#使用AngleSharp库解析html文档

    C#使用AngleSharp库解析html文档

    这篇文章介绍了C#使用AngleSharp库解析html文档的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06

最新评论