Comparator 与Comparable的不同用法
2016-04-10 11:46
387 查看
一、Comparable
Comparable 是在集合内部定义的方法实现的排序,即对象本身实现该接口()。
(1)如String、Integer等基本类型都已实现该接口
(2)对实现该接口的对象list排序时会按照你实现的规则排序。
小结:我们不仅使用的Collections.sort()排序时与该接口有关系,其实在使用TreeMap或者TreeSet时按照这种规则进行排序的,当然你也可以定义一个Comparator接口。
二、Comparator
Comparator 是在集合外部实现的排序。
comparator接口的用法也不仅仅这么简单,尤其是map的排序时会有很多用法,请参考:http://blog.csdn.net/lili429/article/details/51104485
Comparable 是在集合内部定义的方法实现的排序,即对象本身实现该接口()。
(1)如String、Integer等基本类型都已实现该接口
List<String> list = new ArrayList<>(); list.add("c"); list.add("e"); list.add("d"); list.add("b"); list.add("a"); System.err.println(list.toString()); Collections.sort(list); System.err.println(list.toString()); 输出结果是: [c, e, d, b, a] [a, b, c, d, e]其他的基本类型或者已实现Comparable接口的对象也是如此。
(2)对实现该接口的对象list排序时会按照你实现的规则排序。
public class CompareTest { public static void main(String[] args) { List<Person> list = new ArrayList<>(); list.add(new Person(3, "c")); list.add(new Person(1, "a")); list.add(new Person(4, "d")); list.add(new Person(2, "b")); list.add(new Person(6, "f")); list.add(new Person(5, "e")); for (Person p : list) System.err.println(p.name + "====" + p.id); Collections.sort(list); System.err.println("排序之后--------------------------"); for (Person p : list) System.err.println(p.name + "====" + p.id); 输出结果: c====3 a====1 d====4 b====2 f====6 e====5 排序之后-------------------------- a====1 b====2 c====3 d====4 e====5 f====6 } } class Person implements Comparable<Person> { int id; String name; public Person(int i, String n) { this.id = i; this.name = n; } @Override public int compareTo(Person p) { return this.id - p.id; } }
小结:我们不仅使用的Collections.sort()排序时与该接口有关系,其实在使用TreeMap或者TreeSet时按照这种规则进行排序的,当然你也可以定义一个Comparator接口。
二、Comparator
Comparator 是在集合外部实现的排序。
public class CompareTest { public static void main(String[] args) { Map<Person, String> map = new TreeMap<>(new Comparator<Person>() { @Override public int compare(Person o1, Person o2) { return o1.id - o2.id; } }); map.put(new Person(6, "f"), "f"); map.put(new Person(4, "d"), "d"); map.put(new Person(1, "a"), "a"); map.put(new Person(3, "c"), "c"); map.put(new Person(2, "b"), "b"); map.put(new Person(5, "e"), "e"); for (Entry<Person, String> entry : map.entrySet()) { System.err.println(entry.getValue() + "=======" + entry.getKey().id); } } } class Person { int id; String name; public Person(int i, String n) { this.id = i; this.name = n; }
comparator接口的用法也不仅仅这么简单,尤其是map的排序时会有很多用法,请参考:http://blog.csdn.net/lili429/article/details/51104485
相关文章推荐
- java比较器comparator使用示例分享
- Java 中Comparable和Comparator区别比较
- Java中实现Comparable和Comparator对象比较
- Java中实现Comparator接口和用法实例(简明易懂)
- Java函数式编程(九):Comparator
- The Comparator and Comparable in Java
- Java中Comparable和Comparator的区别
- Comparator:将对象进行排序
- java List 排序
- Comparable接口和Comparator类的使用
- Comparable和Comparator
- java小结_015_Treeset集合的compareTo和comparator
- Java CookBook--Creating a Priority Queue--by Tim O'Brien 整理by博主
- comparable和comparator比较
- 对象的比较Comparable与Comparator
- 028.Comparator 比较器的使用
- 集合框架(五)使用Comparable接口和Comparator接口来比较元素
- 后台获取数据排序后在网页显示(Comparator)
- 黑马程序员-Set-HashSet-TreeSet-Comparator-Comparable
- 关于Comparable和Comparator