Comparable、Comparator区别、Comparator升序降序实现

来源:互联网 发布:刘雯的人品怎么样知乎 编辑:程序博客网 时间:2024/06/14 01:33

Comparable与Comparator的区别
可参考:
http://blog.csdn.net/mageshuai/article/details/3849143
总结:
1) 用 Comparator 是策略模式(strategy design pattern),就是不改变对象自身,而用一个策略对象(strategy object)来改变它的行为。
2) Comparable改变对象自身。

Comparator升序降序实现
int compare(Object o1, Object o2) 返回一个基本类型的整型
1) 如果要按照升序排序,
则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)
有如下两种实现方法:
Comparator comparator = new Comparator() {
@Override
public int compare(Integer x, Integer y) {

        //方法一        //  return (x==y)?0:(x<y)?1:(-1);        //方法二        return (x==y)?0:(x-y);    }

};
2) 如果要按照降序排序
则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)
有如下两种实现方法:
Comparator comparator = new Comparator() {
@Override
public int compare(Integer x, Integer y) {

        //方法一        //  return (x==y)?0:(y<x)?1:(-1);        //方法二        return (x==y)?0:(y-x);    }

};

0 0
原创粉丝点击