C#实现集合自定义排序的三种方式

 更新时间:2025年01月24日 10:49:56   作者:AitTech  
在C#中,集合排序是一种常见的操作,它可以帮助我们对集合中的元素进行排序,C#中提供了多种集合排序方法,包括Array.Sort、List.Sort、SortedList和SortedSet等,本文给大家介绍了C#实现集合自定义排序的三种方式,需要的朋友可以参考下

可以通过多种方式实现集合的自定义排序。以下是一些常见的方法:

1. 使用 List<T>.Sort 方法与自定义比较器

List<T> 类提供了一个 Sort 方法,它允许传递一个 IComparer<T> 接口的实现来自定义排序逻辑。

using System;
using System.Collections.Generic;

public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}

public class PersonComparer : IComparer<Person>
{
    public int Compare(Person x, Person y)
    {
        // 按年龄升序排序
        return x.Age.CompareTo(y.Age);
        
        // 如果想按名字排序,可以这样做:
        // return x.Name.CompareTo(y.Name);
        
        // 或者,可以实现更复杂的排序逻辑
    }
}

class Program
{
    static void Main()
    {
        List<Person> people = new List<Person>
        {
            new Person { Name = "Alice", Age = 30 },
            new Person { Name = "Bob", Age = 25 },
            new Person { Name = "Charlie", Age = 35 }
        };

        people.Sort(new PersonComparer());

        foreach (var person in people)
        {
            Console.WriteLine($"{person.Name}, {person.Age}");
        }
    }
}

2. 使用 LINQ 的 OrderBy 方法与自定义键选择器

如果不需要就地排序(即不修改原始集合),而是想创建一个已排序的新集合,可以使用 LINQ 的 OrderBy 方法。可以传递一个键选择器函数来自定义排序逻辑。

using System;
using System.Linq;

class Program
{
    static void Main()
    {
        var people = new List<Person>
        {
            new Person { Name = "Alice", Age = 30 },
            new Person { Name = "Bob", Age = 25 },
            new Person { Name = "Charlie", Age = 35 }
        };

        var sortedPeople = people.OrderBy(p => p.Age).ToList();

        foreach (var person in sortedPeople)
        {
            Console.WriteLine($"{person.Name}, {person.Age}");
        }
    }
}

如果想按多个属性排序,可以使用 ThenBy 方法:

var sortedPeople = people.OrderBy(p => p.Age).ThenBy(p => p.Name).ToList();

3. 实现 IComparable<T> 接口

如果你的类本身就应该有一个默认的排序顺序,可以让该类实现 IComparable<T> 接口。这通常用于希望类的实例在任何情况下都按照相同的逻辑排序时。

public class Person : IComparable<Person>
{
    public string Name { get; set; }
    public int Age { get; set; }

    public int CompareTo(Person other)
    {
        if (other == null) return 1;
        return this.Age.CompareTo(other.Age);
    }
}

// 然后可以直接使用 Sort 方法,不需要传递比较器
people.Sort();

注意,实现 IComparable<T> 接口时也应该重写 Object.Equals 和 Object.GetHashCode 方法,以保持一致性,特别是在集合操作中(如使用哈希表时)。然而,对于排序目的,只实现 IComparable<T> 就足够了。

以上就是C#实现集合自定义排序的三种方式的详细内容,更多关于C#集合自定义排序的资料请关注脚本之家其它相关文章!

相关文章

  • C#基于时间轮调度实现延迟任务详解

    C#基于时间轮调度实现延迟任务详解

    在很多.net开发体系中开发者在面对调度作业需求的时候一般会选择三方开源成熟的作业调度框架来满足业务需求,但是有些时候可能我们只是需要一个简易的延迟任务。本文主要分享一个简易的基于时间轮调度的延迟任务实现,需要的可以参考一下
    2022-12-12
  • C#获取文件MD5值的实现示例

    C#获取文件MD5值的实现示例

    文件的md5值,即文件签名,为了验证文件的正确性,是否被恶意篡改等。每个文件有一个唯一的md5。下面这篇文中就给大家介绍了如何利用C#获取文件MD5值,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • WPF仿微信实现截图功能的方法详解

    WPF仿微信实现截图功能的方法详解

    这篇文章主要介绍了如何利用WPF实现截图功能(仿微信),文中的示例代码讲解详细,对我们学习或工作有一定帮助,需要的可以参考一下
    2022-07-07
  • 使用C#高效解析HTML的实战指南

    使用C#高效解析HTML的实战指南

    在网页开发和数据处理的场景中,经常需要从 HTML 文档里提取有用的信息,C# 作为一门强大的编程语言,提供了丰富的工具和库来实现 HTML 的解析,这篇博客就带你深入了解如何使用 C# 高效地解析 HTML
    2025-01-01
  • C#使用timer实现的简单闹钟程序

    C#使用timer实现的简单闹钟程序

    这篇文章主要介绍了C#使用timer实现的简单闹钟程序,涉及timer控件的使用及音频文件的操作技巧,非常具有实用价值,需要的朋友可以参考下
    2015-03-03
  • Unity多屏幕设置的具体方案

    Unity多屏幕设置的具体方案

    多屏幕指的是一个电脑主机,连接多个显示器,本文主要介绍了Unity多屏幕设置的具体方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • c#泛型学习详解 创建线性链表

    c#泛型学习详解 创建线性链表

    Visual C# 2.0 的一个最受期待的(或许也是最让人畏惧)的一个特性就是对于泛型的支持。这篇文章将告诉你泛型用来解决什么样的问题,以及如何使用它们来提高你的代码质量,还有你不必恐惧泛型的原因
    2014-01-01
  • C#双向链表LinkedList排序实现方法

    C#双向链表LinkedList排序实现方法

    这篇文章主要介绍了C#双向链表LinkedList排序实现方法,涉及C#双向链表的定义与排序技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • C# WinForm 判断程序是否已经在运行,且只允许运行一个实例,附源码

    C# WinForm 判断程序是否已经在运行,且只允许运行一个实例,附源码

    本文主要介绍WinFrom程序中只允许运行一个实例的方法,并有完整的代码示例,希望能给需要的朋友一些帮助。
    2016-04-04
  • C#实现电脑麦克风录音

    C#实现电脑麦克风录音

    这篇文章主要为大家详细介绍了C#实现电脑麦克风录音,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07

最新评论