C# 使用IComparer自定義List類的排序方案


List類中不帶參數的Sort函數可以用來為List類中的元素排序,但如果List類中的元素類型本身不能直接進行比較(如自定義的struct和很多class),或是希望采用更加靈活的自定義比較方式,可以通過繼承了IComparer接口的函數來解決。

代碼示例如下:

1)聲明一個類

/// <summary>
/// 人物類
/// </summary>
public class Person
{
    public string Name;
    public int Age;
    public override string ToString()
    {
        return "Name: " + Name + " Age: " + Age;
    }
}

 

2)聲明一個繼承了接口IComparer的類

/// <summary>
/// 比較人物類實例大小,實現接口IComparer
/// </summary>
public class PersonComparer : IComparer<Person>
{
    public int Compare(Person x, Person y)
    {
        if (x == null && y == null) return 0;
        if (x == null) return -1;
        if (y == null) return 1;

        //TODO:Person類實例X與Y的比較規則
        //按姓名由小到大排列,姓名相同的人年齡大的在前
        {
            int temp = string.Compare(x.Name, y.Name);
            if (temp > 0) return -1;
            else if (temp < 0) return 1;

            if (x.Age > y.Age) return 1;
            if (x.Age < y.Age) return -1;
        }

        return 0;
    }
}

 

3)Main函數,建立一個List,並使用剛建立的PersonComparer類中的規則對List進行排序

static void Main(string[] args)
{
    List<Person> a = new List<Person>();

    a.Add(new Person() { Name = "Tsybius", Age = 23 });
    a.Add(new Person() { Name = "Galatea", Age = 21 });
    a.Add(new Person() { Name = "Lucius", Age = 22 });
    a.Add(new Person() { Name = "Septimus", Age = 22 });
    a.Add(new Person() { Name = "Octavius", Age = 22 });
    a.Add(new Person() { Name = "Lucius", Age = 24 });

    //輸出a中全部元素
    Console.WriteLine("排序前");
    foreach (var v in a)
    {
        Console.WriteLine(v.ToString());
    }
    Console.WriteLine("-");

    //對a進行排序
    a.Sort(new PersonComparer());

    //輸出a中全部元素
    Console.WriteLine("排序后");
    foreach (var v in a)
    {
        Console.WriteLine(v.ToString());
    }
    Console.WriteLine("-");

    Console.ReadLine();
}

 

4)程序運行示例

END


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM