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 ...
随机推荐
- 使用Spring-data-jpa(2)(三十一)
创建实体 创建一个User实体,包含id(主键).name(姓名).age(年龄)属性,通过ORM框架其会被映射到数据库表中,由于配置了hibernate.hbm2ddl.auto,在应用启动的时候框 ...
- MSOCache office问题
\MSOCache 链接:https://pan.baidu.com/s/1dVvjYnD0D6DG6oFK_Mww2w密码:qrvp undefied
- Sql server中如何将表A和表B的数据合并(乘积方式)
sql server中如何将表A 和表B的数据合并成乘积方式,也就是说表A有2条数据,表B有3条数据,乘积后有6条数据, 这就要用到sql中的笛卡尔积方式了 1.什么是笛卡尔积 笛卡尔积在SQL中的实 ...
- java字符串根据空格截取并存进ArrayList,并在每个元素前后加上/
public class List { public static void main(String[] args) { String s = "abc nnn ooo/xzsxc bs&q ...
- eclipse项目环境搭建(做了好多遍,老是忘记,以此文帮助记忆)
今天把eclipse的环境搭建好(不能用myeclipse好忧伤). 要求: 1.在svn上管理项目,要下载svn插件. 2.是web所以要用到tomcat插件. 3.将项目运行起来. 流程: ecl ...
- Android : 跟我学Binder --- (1) 什么是Binder IPC?为何要使用Binder机制?
目录: Android : 跟我学Binder --- (1) 什么是Binder IPC?为何要使用Binder机制? Android : 跟我学Binder --- (2) AIDL分析及手动实现 ...
- 4.5 C++重载、覆盖和遮蔽
参考:http://www.weixueyuan.net/view/6375.html 总结: 函数签名包括函数名和函数参数的个数.顺序以及参数数据类型. 需要注意的是函数签名并不包含函数返回值部分, ...
- window.location.replace()与window.location.href()区别
有3个页面 a,b,c 如果当前页面是c页面,并且c页面是这样跳转过来的:a->b->c 1:b->c 是通过window.location.replace("..xx/c ...
- centos7中docker操作
docker部署nginx 1. 下载nginx [root@localhost my.Shells]# docker images REPOSITORY TAG IMAGE ID CREATED S ...
- Windows下安装Tensorflow报错 “DLL load failed:找不到指定的模块"
Windows下安装完tensorflow后,在cmd下运行python后import tensorflow出现如下错误: Traceback (most recent call last): Fi ...