亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#基礎(chǔ)教程之IComparable用法,實(shí)現(xiàn)List<T>.sort()排序

 更新時(shí)間:2015年02月22日 09:16:10   投稿:hebedich  
這篇文章主要介紹了C#的一些基礎(chǔ)知識(shí),主要是IComparable用法,實(shí)現(xiàn)List<T>.sort()排序,非常的實(shí)用,這里推薦給大家。

 List<T>.sort()可以實(shí)現(xiàn)對(duì)T的排序,比如List<int>.sort()執(zhí)行后集合會(huì)按照int從小到大排序。如果T是一個(gè)自定義的Object,可是我們想按照自己的方式來(lái)排序,那該怎么辦呢,其實(shí)可以用過(guò)IComparable接口重寫(xiě)CompareTo方法來(lái)實(shí)現(xiàn)。流程如下:

      一.第一步我們申明一個(gè)類Person但是要繼承IComparable接口:

復(fù)制代碼 代碼如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TestIComparable
{
    public class Person : IComparable<Person>
    {
        public string Name { get; set; }
        public int Age { get; set; }
        public int CompareTo(Person obj)
        {
            int result;
            if (this.Name == obj.Name && this.Age == obj.Age)
            {
                result = 0;
            }
            else
            {
                if (this.Name.CompareTo(obj.Name) > 0)
                {
                    result = 1;
                }
                else if (this.Name == obj.Name && this.Age > obj.Age)
                {
                    result = 1;
                }
                else
                {
                    result = -1;
                }
            }
            return result;
        }
        public override string ToString()
        {
            return this.Name + "-" + this.Age;
        }
    }
}

  二.然后在主函數(shù)里面調(diào)用sort方法即可.類就會(huì)按照姓名從小到大,如果姓名相同則按照年齡從小到大排序了。

復(fù)制代碼 代碼如下:

public class Program
{
    public static void Main(string[] args)
    {
        List<Person> lstPerson = new List<Person>();
        lstPerson.Add(new Person(){ Name="Bob",Age=19});
        lstPerson.Add(new Person(){ Name="Mary",Age=18});
        lstPerson.Add(new Person() { Name = "Mary", Age = 17 });
        lstPerson.Add(new Person(){ Name="Lily",Age=20});
        lstPerson.Sort();
        Console.ReadKey();
    }
}

   三,如果不繼承IComparable接口,我們?cè)撊绾螌?shí)現(xiàn)排序呢??梢允褂肔inq來(lái)實(shí)現(xiàn)。其實(shí)效果是一樣的,只是如果類的集合要經(jīng)常排序的話,建議使用繼承接口的方法,這樣可以簡(jiǎn)化sort的代碼,而且更容易讓人看懂。

復(fù)制代碼 代碼如下:

public static void Main(string[] args)
        {
            List<Person> lstPerson = new List<Person>();
            lstPerson.Add(new Person(){ Name="Bob",Age=19});
            lstPerson.Add(new Person(){ Name="Mary",Age=18});
            lstPerson.Add(new Person() { Name = "Mary", Age = 17 });
            lstPerson.Add(new Person(){ Name="Lily",Age=20});
            lstPerson.Sort((x,y) =>
            {
                int result;
                if (x.Name == y.Name && x.Age == y.Age)
                {
                    result = 0;
                }
                else
                {
                    if (x.Name.CompareTo(y.Name) > 0)
                    {
                        result = 1;
                    }
                    else if (x.Name == y.Name && x.Age > y.Age)
                    {
                        result = 1;
                    }
                    else
                    {
                        result = -1;
                    }
                }
                return result;
            });
            Console.ReadKey();
        }

相關(guān)文章

最新評(píng)論