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(...)方法进行排序. ...
随机推荐
- 【java面试】集合类篇
java中主要的类集合接口如下 Collection ├List │├LinkedList │├ArrayList │└Vector │ └Stack └Set Map ├Hashtable ├Has ...
- 看透Spring MVC:源代码分析与实践 (Web开发技术丛书)
第一篇 网站基础知识 第1章 网站架构及其演变过程2 1.1 软件的三大类型2 1.2 基础的结构并不简单3 1.3 架构演变的起点5 1.4 海量数据的解决方案5 1.4.1 缓存和页面静态化5 1 ...
- 之前见汤姆大叔 写过一系列的 js 深入理解 呢 很是感觉经典
最近要把这些给翻个遍 加油 js 隐式全局变量 读后感 1:js 没有变量名称是否重复定义的检查,在cshrp里有这样的检查, 没有变量名称重复的检查,这样 当变量名称 重复定义的时候 相同命名的变 ...
- 巨坑练习题!!!—— Car的旅行线路
在看题目之前,请童鞋们做好心理准备╮(╯▽╰)╭ 题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游. 她知道每个城市都有四个飞机场,分别位于一个矩形的四个顶点上,同一个城市中两个机场之 ...
- AI领域有什么职业?怎样才能在AI领域找到工作?
AI领域是一个很吃香的行业,在这个行业中,很多人都是高薪的,而且有些学生为了以后能够接触到这个行业,都在大学的时候,学习这个专业,那么大家知道AI领域有什么职业吗?下面我们就来给大家讲解一下. 1.算 ...
- ArcGIS10.2安装教程
1,首先要下载Arcgis 10.2软件,很大大约有2个多G.下载后分别全部解压. 2,首先,安装相应的LicenseManager,双击Arcgis 10.2打开安装界面,选择安装. 3,开始安装L ...
- 聊一聊 MySQL 中的数据编辑过程中涉及的两阶段提交
MySQL 数据库中的两阶段提交,不知道您知道不?这篇文章就简单的聊一聊 MySQL 数据库中的两阶段提交,两阶段提交发生在数据变更期间(更新.删除.新增等),两阶段提交过程中涉及到了 MySQL 数 ...
- Python3-ORM-Sqlalchemy
目录: ORM介绍 sqlalchemy安装 sqlalchemy基本使用 多外键关联 多对多关系 表结构设计作业 1. ORM介绍 orm英文全称object relational mapping, ...
- 聊聊SpringBoot | 第一章:快速搭建SpringBoot第一个应用
快速搭建SpringBoot第一个应用 1.简介 本章仅介绍如何快速搭建第一个SpringBoot应用,细节内容下一章再做讲解,如果有需要,各位可以直接到Spring官网去了解. 从 Spring B ...
- Jpofiler
参考链接: https://blog.csdn.net/u010638673/article/details/81703942