zoukankan      html  css  js  c++  java
  • 【转载】C#中自定义Sort的排序规则IComparable接口

      C#中的List集合在排序的时候,如果不使用Lambda表达式进行排序的话,一般调用Sort()方法进行排序,如果希望Sort()方法排序后的结果跟我们预想的效果一致或者按照我们自定义的规则排序,则需要将对应的实体继承IComparable接口来实现。

          MSDN上给IComparable接口的定义为:定义由值类型或类实现的特定于类型的通用比较方法,旨在对其实例进行排序,使自建类的数组可以使用Array. Sort方法进行排序。自建类继承IComparable接口后,必须实现CompareTo方法,该方法参数是一个T类型的对象,返回值必须是-1,0,1中之一。

         下面以一个例子来讲解这个自定义排序,我们定义一个Person人员类,该类包含Name和Age两个属性,要求在数组中调用Sort()方法排序的时候,按年龄Age属性从小到大排序,相应的实现如下代码所示:

    class Person : IComparable
        {
            public Person(string name, int age)
            {
                Name = name; Age = age;
            }
            public string Name { get; set; }
            public int Age { get; set; }
           public  int CompareTo(object obj)  //实现该比较方法即可
            {
                if (obj is Person)
                {
                    Person p = obj as Person;
                    return this.Age.CompareTo(p.Age);
                }
                else
                {
                    throw new ArgumentException("Object to compare to is not a Person object");
                }
            }
        }

    然后我们写个控制台程序测试下上述的排序结果,测试程序如下:

    static void Main(string[] args)
            {
                List<Person> personlist = new List<Person>();
                personlist.Add(new Person("马六",89));
                personlist.Add(new Person("张三",33));
                personlist.Add(new Person("李四",3));
                personlist.Add(new Person("王五", 244));
                personlist.Sort();
                foreach(Person p in personlist)
                {
                    Console.Write("姓名:"+p.Name+"  年龄:"+p.Age);
                    Console.Write("
    ");
                    
                }
                Console.ReadKey(); 
            }

    运行之后,我们查看下输出的结果信息,完美的达到了我们预期的效果,输出的结果如下:

    姓名:李四    年龄:3
    姓名:张三    年龄:33
    姓名:马六    年龄:89
    姓名:王五    年龄:244

    扩展阅读:目前国内主流的云服务器厂商有哪些_IT技术小趣屋

    备注:原文转载自C#中自定义Sort的排序规则IComparable接口_IT技术小趣屋

    博主个人技术交流群:960640092,博主微信公众号如下:

  • 相关阅读:
    各种平衡树板子
    字符串板子
    数学公式/定理/板子整理
    线性筛 板子整理
    set乱搞时需注意的坑点
    可持久化数据结构板子整理(可持久化 线段树/字典树/可并堆)
    洛谷p2483 模板k短路 可持久化可并堆
    p4929 DLX舞蹈链
    百度ai 图像增强与特效
    百度ai php请求获取access_token返回false
  • 原文地址:https://www.cnblogs.com/xu-yi/p/10623679.html
Copyright © 2011-2022 走看看