Java中的comparable接口和Comparator接口的区别
一.comparable和Comparator的区别
1、Comparable和Comparator都是用来实现集合中元素的比较、排序的。
2、Comparable是在类内部定义的方法实现的排序,位于java.lang下。
3、Comparator是在类外部实现的排序,位于java.util下。
4、实现Comparable接口需要覆盖compareTo方法,实现Comparator接口需要覆盖compare方法。
5、Comparable接口将比较代码嵌入需要进行比较的类的自身代码中,而Comparator接口在一个独立的类中实现比较。
二.深度认识
首先Comparable这个接口是使用在你需要排序的元素类上的。
而Comparator不是使用在你需要排序的元素类上的,它需要实现一个子类对象,将子类对象传入可以排序的集合中(TreeSet)。
当你想去使用comparable接口时必须去修改源代码,因为他是建立在需要被排序的元素类上的。
那你要是想对String类进行你自己想要的排序怎么办呢?(举例子,不要抬杠)
首先你不能去修改源代码,第二String类是final类不能继承。
那么此时你就可以使用Comparator接口实现在类外的排序
三.实例
1.对元素类Node实现comparable接口
package com.cjm.lambda; import java.util.Set;
import java.util.TreeSet;
/**
*
* @author 小明
*
*/
public class SetSortlambda {
public static void main(String[] args) {
Set<Node> set = new TreeSet<>();
set.add(new Node("zs",10));
set.add(new Node("zs1",110));
set.add(new Node("zs1",10));
set.add(new Node("zszx",100));
set.add(new Node("zzxs",10));
System.out.println(set);
}
}
/*
* 元素本生实现comparator接口
*/
class Node implements Comparable<Node> {
int num;
String str; public Node(String str,int num) {
this.str=str;
this.num = num;
} @Override
public int compareTo(Node o) {
if (this.str == null) {
return -1;
} else {
if (o.str == null) {
return 1;
} else {
if (this.str.length() < o.str.length()) {
return -1;
} else {
if (this.str.length() > o.str.length()) {
return 1;
} else {
if (this.num < o.num) {
return -1;
} else {
if (this.num > o.num) {
return 1;
} else {
return 0;
}
}
}
}
}
} } /* (non-Javadoc)
* @see java.lang.Object#toString()
*/
@Override
public String toString() {
return str+num;
} }
2.使用Comparator接口,实现一个Comparator接口的对象(采用内部类的方式)
package com.cjm.lambda; import java.util.Comparator;
import java.util.Set;
import java.util.TreeSet; /**
* Compararator接口实现排序
*
* @author 小明
*
*/ public class Text {
public static void main(String[] args) {
Set<Node> set = new TreeSet<>(new Comparator<Node>() { @Override
public int compare(Node node1, Node node2) {
if (node1.str.length() < node2.str.length()) {
return 1;
} else {
if (node1.str.length() > node2.str.length()) {
return -1;
} else {
if (node1.num < node2.num) {
return 1;
} else {
if (node1.num > node2.num) {
return -1;
} else {
return 0;
}
}
}
}
}
});
set.add(new Node("zs", 10));
set.add(new Node("zs1", 110));
set.add(new Node("zs1", 10));
set.add(new Node("zszx", 100));
set.add(new Node("zzxs", 10));
System.out.println(set);
}
}
Java中的comparable接口和Comparator接口的区别的更多相关文章
- Java中的Comparable<T>和Comparator<T>接口
有的时候在面试时会被问到Comparable<T>和Comparator<T>的区别(或者Java中两种排序功能的实现区别). 1) 在使用普通数组的时候,如果想对数据进行排序 ...
- Java中实现对象的比较:Comparable接口和Comparator接口
在实际应用中,我们往往有需要比较两个自定义对象大小的地方.而这些自定义对象的比较,就不像简单的整型数据那么简单,它们往往包含有许多的属性,我们一般都是根据这些属性对自定义对象进行比较的.所以Java中 ...
- Java6.0中Comparable接口与Comparator接口详解
Java6.0中Comparable接口与Comparator接口详解 说到现在,读者应该对Comparable接口有了大概的了解,但是为什么又要有一个Comparator接口呢?难道Java的开发者 ...
- Java:实现对象的比较 comparable接口和comparator接口
在实际应用中,我们往往有需要比较两个自定义对象大小的地方.而这些自定义对象的比较,就不像简单的整型数据那么简单,它们往往包含有许多的属性,我们一般都是根据这些属性对自定义对象进行比较的.所以Java中 ...
- java中Comparatable接口和Comparator接口的区别
1.不同类型的排序规则 .自然排序是什么? 自然排序是一种升序排序.对于不同的数据类型,升序规则不一样: BigDecimal BigInteger Byte Double Float Int ...
- Java—集合框架 Collections.sort()、Comparable接口和Comparator接口
Collentions工具类--java.util.Collections Collentions是Java集合框架中,用来操作集合对象的工具类,也是Java集合框架的成员,与List.Map和Set ...
- 来吧,一文彻底搞懂Java中的Comparable和Comparator
大家好,我是沉默王二,今天在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题.比如说:Java 的 Comparable 和 Comparator 是兄弟俩吗?像这类灵魂拷问 ...
- Java中的集合(十一) 实现Map接口的TreeMap
Java中的集合(十一) 实现Map接口的TreeMap 一.TreeMap简介(基于JDK1.8) TreeMap是基于红黑树数据结构,是一个key-value的有序集合,该映射根据其键的自然顺序进 ...
- Comparable接口与Comparator接口的比较————总结
之前的两篇文章主要学习了Comparable接口和Comparator接口的学习.既然已经学习完了,现在就趁热打铁,进行总结吧! Comparable接口和Comparator接口的共同点: 1. 都 ...
- Java中的集合(十三) 实现Map接口的Hashtable
Java中的集合(十三) 实现Map接口的Hashtable 一.Hashtable简介 和HashMap一样,Hashtable采用“拉链法”实现一个哈希表,它存储的内容是键值对(key-value ...
随机推荐
- 《高性能SQL调优精要与案例解析》新书样章
该书样章已上传,需要的同学可以通过如下地址下载:http://www.itpub.net/thread-2091839-1-1.html http://www.itpub.net/thread-209 ...
- Jupyter 快速入门——写python项目博客非常有用!!!
from:https://blog.csdn.net/m0_37338590/article/details/78862488 一.简介: Jupyter Notebook(此前被称为 IPython ...
- android studio maven 仓库的使用
转自:http://www.cnblogs.com/sihaixuan/p/4852974.html 原文:How to distribute your own Android library thr ...
- django自定义标签,int转化为str类型
1.在app中创建templatetags目录,目录名必须为templatetags 2.在目录templatetags中创建一个.py文件,例如 strFilter.py strFilter.py ...
- Ubuntu下如何访问Windows磁盘?
有些同学的电脑原来是Windows系统的,但为了需要,又下载了一个Ubuntu系统,变成双系统的电脑. 但是,在Ubuntu下,Windows的磁盘是打不开的,用网盘或者U盘又是很不方便,所以ljn教 ...
- UVa 10891 - Game of Sum 动态规划,博弈 难度: 0
题目 https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&a ...
- docker 将正在运行的容器打包为镜像
将容器打包成镜像 docker commit -a "runoob.com" -m "my apache" 容器名称或id 打包的镜像名称:标签 OPTIONS ...
- Integer与int的区别(转)
如果面试官问Integer与int的区别:估计大多数人只会说道两点,Ingeter是int的包装类,int的初值为0,Ingeter的初值为null.但是如果面试官再问一下Integer i = 1; ...
- 在ros功能包CMakeLists.txt中获取所在功能包的路径 便于添加第三方库的相对路径
在 ros 功能包中要使用第三方的动态库,将其放在系统默认库路径和使用绝对路径均不可取,这样的话可移植性较差,将该功能包移到其它电脑时要重新配置依赖库的路径,太麻烦了. 于是找到下面这个方法,解决了R ...
- 7系列FPGA远程更新方案-QuickBoot(转)
reference: http://xilinx.eetrend.com/d6-xilinx/article/2014-04/7009.html reference : quickboot meth ...