Java连载89-SorteSet、Comparable接口
一、 SortedSet集合直接举例
package com.bjpowernode.java_learning;
import java.util.*;
/**
* java.util.Set
* java.util.SortedSet;无序不可以重复,但是存进去的元素可以按照元素大小顺序自动进行排列
* java.utile.TreeSet;
*/
import java.text.*;
public class D89_1_SortedSet {
public static void main(String[] args) throws ParseException{
//创建集合
SortedSet ss = new TreeSet();
//添加元素
ss.add(10);//自动装箱
ss.add(12);
ss.add(5);
ss.add(78);
Iterator i = ss.iterator();
while(i.hasNext()) {
Object element = i.next();
System.out.println(element);
}
//String
SortedSet sts = new TreeSet();
sts.add("Jack");
sts.add("SUN");
sts.add("COOK");
sts.add("LUCKY");
Iterator i2 = sts.iterator();
while(i2.hasNext()) {
Object element = i2.next();
System.out.println(element);
}
//日期Date
String t1 = "2008-08-08";
String t2 = "2009-08-08";
String t3 = "2008-09-08";
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Date dt1 = sdf.parse(t1);
Date dt2 = sdf.parse(t2);
Date dt3 = sdf.parse(t3);
SortedSet sss = new TreeSet();
sss.add(t1);
sss.add(t2);
sss.add(t3);
//遍历
Iterator its = sss.iterator();
while(its.hasNext()) {
Object element = its.next();
if(element instanceof Date) {
Date d = (Date)element;
System.out.println(sdf.format(d));
}
}
}
}

二、实现Comparable接口
1.SortedSet集合存储元素为什么可以进行自动排序
因为被存储的元素实现了Comparable接口,SUN编写TreeSet集合在添加元素的时候,会调用compareTo方法完成比较。
package com.bjpowernode.java_learning;
import java.util.*;
import java.lang.*;
public class D89_2_ImplementComparable {
public static void main(String[] args) {
SortedSet s = new TreeSet();
User89 u1 = new User89(3);
User89 u2 = new User89(45);
User89 u3 = new User89(12);
User89 u4 = new User89(25);
s.add(u1);
s.add(u2);
s.add(u3);
s.add(u4);
Iterator i = s.iterator();
while(i.hasNext()) {
Object o = i.next();
System.out.println(o.toString());
}
}
}
class User89 implements Comparable{
int age;
User89(int age){
this.age = age;
}
public String toString() {
return age+"";
}
//实现java.lang.Comparable;接口中的compareTo方法
//该方法程序员负责,SUN提供的程序已经调用了该方法
//需求:按照User89的年龄进行排序
public int compareTo(Object o) {
//编写一个规则
int age1 = this.age;
int age2 = ((User89)o).age;
return age2-age1;
}
}

我们改一下最后一行代码:return
age1-age2;
然后编译运行

总结:我们实现的compareTo方法的时候,它的底层是一个二叉树
当返回结果大于0,那么比较的元素就会放在右子树(相当于比较出来了结果:大于);同理,当返回结果小于0,那么比较的元素就会放在左子树;
如果返回零的话,说明这两个对象是完全相同的,因此只会存储一个对象。(可以看一看Comparable源码,了解一下)。
三、源码:
D89_1_SortedSet.java
D89_2_ImplementComparable.java
https://github.com/ruigege66/Java/blob/master/D88_1_HashSetExample.java
https://github.com/ruigege66/Java/blob/master/D89_2_ImplementComparable.java
2.CSDN:https://blog.csdn.net/weixin_44630050
3.博客园:https://www.cnblogs.com/ruigege0000/
4.欢迎关注微信公众号:傅里叶变换,个人公众号,仅用于学习交流,后台回复”礼包“,获取大数据学习资料

Java连载89-SorteSet、Comparable接口的更多相关文章
- Effective Java 【考虑实现Comparable接口】
Effective Java --Comparable接口 compareTo方法是Comparable接口的唯一方法.类实现了Comparable接口,表明它的实例具有内在的排序关系. 自己实现co ...
- Java Comparator方法 和 Comparable接口
默认的排序方法: 让类继承Comparable接口,重写compareTo方法. 示例代码: package com.imooc.collection; import java.util.HashSe ...
- Java自定义排序:继承Comparable接口,重写compareTo方法(排序规则)
代码: 1 import java.util.*; 2 3 /** 4 * 学习自定义排序:继承Comparable接口,重写compareTo方法(排序规则). 5 * TreeMap容器的Key是 ...
- Comparable接口的实现和使用
1.什么是Comparable接口 此接口强行对实现它的每个类的对象进行整体排序.此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 .实现此接口的对象列表(和数组)可 ...
- java中的Comparable接口
类对象之间比较"大小"往往是很有用的操作,比如让对象数组排序时,就需要依赖比较操作.对于不同的类有不同的语义.如Student类,比较2个学生对象可以比较他们的score分数来评判 ...
- Java 之 比较器( Comparator接口与 Comparable 接口)
一.定制排序:java.util.Comparator 接口 强行对某个对象 collection 进行整体排序 的比较函数.可以将 Comparator 传递给 sort 方法(如 Collecti ...
- Java集合中Comparator和Comparable接口的使用
在Java集合中,如果要比较引用类型泛型的List,我们使用Comparator和Comparable两个接口. Comparable接口 -- 默认比较规则,可比较的 实现该接口表示:这个类的实例可 ...
- Java中的Comparable接口和Comparator接口
Comparator位于包java.util下,比较器,是在集合外部定义排序.Comparable位于包java.lang下,代表当前对象可比较的,是在集合内部实现排序. Comparable代表一个 ...
- java 中的2个接口 Comparable和Comparator
像Integer.String这些类型的数据都是已经实现Comparable接口的,所以对这些类型可以直接通过Arrays.sort(...)和Collections.sort(...)方法进行排序. ...
随机推荐
- 安装anaconda python时只能安装到默认文件夹&& 安装提示文件夹以存在问题
这个问题困扰了两次,网上说可以,我就是不行,查了半天没找到解决方法, 后来装在C盘里, 之后在百度知道(ID:幸福999快乐)发现解决办法后来才发现问题. 在安装的时候,要安装的目标文件夹不需要先在安 ...
- Win10如何关闭最近使用文件夹
如果默认开启了最近使用文件夹功能的话,最近浏览的文件就会被记录下来.所以看完各种教学资料后,并不是关掉或者重启别人就不知道你看了什么. 方法一: Win10怎么关闭最近使用文件夹 如何清理使用痕迹 从 ...
- BZOJ 2095 Bridges
题目传送门 分析: 首先就是二分 然后... 混合图欧拉回路是sm... 看了题解Orz 首先要回到原来的点的话,那么每个点入度和出度要相等... 这..和网络流进入点之后就出去不是一样的吗.. 又由 ...
- 聊一聊 MySQL 数据库中的那些锁
在软件开发中,程序在高并发的情况下,为了保证一致性或者说安全性,我们通常都会通过加锁的方式来解决,在 MySQL 数据库中同样有这样的问题,一方面为了最大程度的利用数据库的并发访问,另一方面又需要保证 ...
- Docker获取镜像报错docker: Error response from daemon
docker: Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: request canceled ...
- LXC(LinuX Container)之namespaec和cgroup
LXC(LinuX Container)之namespaec和cgroup namespace概述 从操作系统级上实现了资源的隔离,它本质上是宿主机上的进程(容器进程),所以资源隔离主要就是指进程资源 ...
- Macbook 安装 opencv(cv2) 及在pycharm 下的使用
python和opencv的安装都很顺利,就是在PyCharm下的配置浪费了一点时间. 一.原料 1.max系统 2.python(本文用的版本是3.6.5) 3.opencv(本文中使用的版本是3. ...
- Web自动化测试项目(五)测试结果通知
一.邮件通知 使用第三方邮件发送库yagmail github地址:https://github.com/kootenpv/yagmail 安装 pip3 install yagmail demo.p ...
- 云原生 - Why is istio(二)
出处:https://cizixs.com/2018/08/26/what-is-istio 创作不易,在满足创作共用版权协议的基础上可以转载,但请以超链接形式注明出处. 前言 随着微服务架构的流行, ...
- MySQL5.7 中的query_cache_size
摘自:http://jackyrong.iteye.com/blog/2173523 1 原理 MySQL查询缓存保存查询返回的完整结果.当查询命中该缓存,会立刻返回结果,跳过了解析,优化和执行 ...