数组中的对象排序--IComparable

本文介绍了如何通过实现IComparable接口中的CompareTo方法,使得数组中的对象能够按照特定属性进行排序。通过实例展示了在.NET框架下使用Array类的Sort方法对Person类数组进行排序的过程,并详细解释了类中实现的接口成员。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

l给数组中的对象排序
(实现IComparable的重要性 )
要使数组中的对象能够排序,其对象必须实现IComparable接口的CompareTo方法。可以使用Array类的Sort方法实现排序。

 

 数组的排序:

 Person[] persons = new Person[3];
        Person wm = new Person("郭", "明");
       Person wm1 = new Person("王", "明");
        persons[0] = wm;
        persons[1] = new Person("小", "万");
        persons[2] = new Person("刘", "心");
        Array.Sort(persons);
        foreach (Person  p in persons )
        {
           Response.Write(p.FirstName +p.LastName +"<br/>");
        }

类中:(利用接口)

public class Person:IComparable 
{

private string firstname;

    public string FirstName
    {
        get { return firstname; }
        set { firstname = value; }
    }
    private string lastname;

    public string LastName
    {
        get { return lastname; }
        set { lastname = value; }
    }

 

//IComparable 成员

  public int CompareTo(object obj)
   {
       Person p = obj as Person;
       if (p == null)
       {
           throw new ArgumentException("obj is not a person");
       }
       int first = this.firstname.CompareTo(p.firstname);
       if (first == 0)//如果firstname相同则比较lastname
       {
           first = this.lastname.CompareTo(p.lastname);
           return first;
       }
       else
           return first;
          }

}

按照数组中元素录入的先后顺序进行排序
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值