自定义类比较大小以及按照规则排序。

  我们在开发的时候会创建许多对象,而这些对象有时候可能需要排序,排序就需要比较大小,但是java没有提供比较自定义对象大小的方法,所以需要我们自己实现。
  实现比较自定义对象有两种方法,实现接口Comparable或者Comparator,今天我根据我自己的理解讲讲如何实现Comparable接口来比较自定义对象的大小。
  第一步:自定义Person类,并且实现接口Comparable,并且重写接口中的方法 public int compareTo(Object obj)。

class Person implements Comparable {
    private int age;
    //假设对象根据年龄比较大小,且排序顺序为降序。
    @override
    public int compareTo(Object obj){
        //异常判断
        if(null == o){
            throw new NullPointerException("所比较对象不能为空");
        }

        Person p = (Person)o;
        return obj.age - this.age;
    }
}
第二步:外部调用
public static void main(String[] args){
    Person p1 = new Person(4);
    Person p2 = new Person(6);
    Person p3 = new Person(1);
    Person[] ps = new Person[3];
    ps[0] = p1;
    ps[1] = p2;
    ps[2] = p3;
    //如果使用系统自带的排序方法,就必须要实现Comparable接口。
    Array.sort(ps);
}
阅读更多
个人分类: Java
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭