Comparable和Comparator的区别
时间: 2023-11-15 11:59:17 浏览: 311
Comparable和Comparator都是Java中用于排序的接口,但它们有一些区别:
1. Comparable是内在比较器,实现这个接口的类的对象可以直接比较,而Comparator是外在比较器,需要单独实现一个比较器类。
2. 实现Comparable接口的类的对象可以用作“有序映射(如TreeMap)”中的键或“有序集合(TreeSet)”中的元素,而不需要指定比较器。而使用Comparator则需要在创建集合时指定比较器。
3. Comparable接口的排序方式是自然排序,而Comparator接口可以实现自定义排序。
4. 实现Comparable接口需要修改原先的实体类,而Comparator不需要修改原先的类的实现一个新的比较器。
总之,如果需要对一个类进行排序,且这个类已经实现了Comparable接口,那么可以直接使用Collections.sort方法进行排序;如果需要实现自定义排序或者对一个类进行多种排序方式,那么可以使用Comparator接口。
相关问题
comparable和comparator区别
comparable 是 Java 中的一个接口,它只有一个方法 compareTo()。实现了 comparable 接口的类的对象可以直接使用 Collections.sort() 或 Arrays.sort() 方法进行排序。
comparator 是 Java 中的一个接口,它有两个方法 compare() 和 equals()。它主要用来在实现了 comparable 接口的类中,自定义排序规则,也可以用来对不支持 comparable 接口的类的对象进行排序。可以使用 Collections.sort(List<T> list, Comparator<? super T> c) 或 Arrays.sort(T[] a, Comparator<? super T> c) 。
comparable和comparator区别用法
Comparable和Comparator都是Java中用于排序的接口,但它们有不同的用途和实现方式。
Comparable是一个内部排序的接口,它是在要排序的对象类中实现的。它只有一个方法compareTo(),用于比较该对象与另一个对象的大小。compareTo()方法返回一个整数,表示该对象与比较对象的大小关系。如果该对象小于比较对象,则返回负数;如果该对象等于比较对象,则返回0;如果该对象大于比较对象,则返回正数。实现Comparable接口的类可以通过Collections.sort()方法进行排序。
Comparator是一个外部排序的接口,它是在排序时单独实现的。它有一个方法compare(),用于比较两个对象的大小。compare()方法返回一个整数,表示第一个对象与第二个对象的大小关系。如果第一个对象小于第二个对象,则返回负数;如果第一个对象等于第二个对象,则返回0;如果第一个对象大于第二个对象,则返回正数。Comparator接口可以用于对任意类的对象进行排序,可以通过Collections.sort()方法的第二个参数来指定Comparator。
因此,如果要对某个类的对象进行排序,可以实现Comparable接口并重写compareTo()方法;如果要对任意类的对象进行排序,可以实现Comparator接口并重写compare()方法。
阅读全文
相关推荐














