您的位置:首页 > 编程语言 > Java开发

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

2016-08-12 13:52 826 查看
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);
}


};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java