Comparable、Comparator区别、Comparator升序降序实现
2018-03-09 11:50
357 查看
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) {
2
3
4
5
};
2) 如果要按照降序排序
则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)
有如下两种实现方法:
Comparator comparator = new Comparator() {
@Override
public int compare(Integer x, Integer y) {
1
2
3
4
5
};
可参考:
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); }1
2
3
4
5
};
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); }
1
2
3
4
5
};
相关文章推荐
- Comparable、Comparator区别、Comparator升序降序实现
- 实现comparable与comparator区别
- Java中,如果想要排序,实现Comparator接口 //与Comparable 的区别?
- Comparable与Comparator的区别
- Java中Comparable与Comparator的区别
- Java中Comparable与Comparator的区别
- Comparable和Comparator接口的联系与区别
- Comparator与Comparable接口实现对象排序
- Comparable接口与comparator接口的区别与联系
- comparator接口与Comparable接口的区别
- java comparable和Comparator 区别
- Comparable与Comparator的区别
- 集合框架-Comparator和Comparable的区别
- Comparable与Comparator的区别
- Java语言中comparable与comparator接口的区别
- Java中Comparable和Comparator区别
- Comparable与Comparator的区别
- Comparable接口与Comparator接口的区别
- Comparable 与 Comparator 的区别
- Comparable与Comparator的区别