一、 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接口的更多相关文章

  1. Effective Java 【考虑实现Comparable接口】

    Effective Java --Comparable接口 compareTo方法是Comparable接口的唯一方法.类实现了Comparable接口,表明它的实例具有内在的排序关系. 自己实现co ...

  2. Java Comparator方法 和 Comparable接口

    默认的排序方法: 让类继承Comparable接口,重写compareTo方法. 示例代码: package com.imooc.collection; import java.util.HashSe ...

  3. Java自定义排序:继承Comparable接口,重写compareTo方法(排序规则)

    代码: 1 import java.util.*; 2 3 /** 4 * 学习自定义排序:继承Comparable接口,重写compareTo方法(排序规则). 5 * TreeMap容器的Key是 ...

  4. Comparable接口的实现和使用

    1.什么是Comparable接口 此接口强行对实现它的每个类的对象进行整体排序.此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 .实现此接口的对象列表(和数组)可 ...

  5. java中的Comparable接口

    类对象之间比较"大小"往往是很有用的操作,比如让对象数组排序时,就需要依赖比较操作.对于不同的类有不同的语义.如Student类,比较2个学生对象可以比较他们的score分数来评判 ...

  6. Java 之 比较器( Comparator接口与 Comparable 接口)

    一.定制排序:java.util.Comparator 接口 强行对某个对象 collection 进行整体排序 的比较函数.可以将 Comparator 传递给 sort 方法(如 Collecti ...

  7. Java集合中Comparator和Comparable接口的使用

    在Java集合中,如果要比较引用类型泛型的List,我们使用Comparator和Comparable两个接口. Comparable接口 -- 默认比较规则,可比较的 实现该接口表示:这个类的实例可 ...

  8. Java中的Comparable接口和Comparator接口

    Comparator位于包java.util下,比较器,是在集合外部定义排序.Comparable位于包java.lang下,代表当前对象可比较的,是在集合内部实现排序. Comparable代表一个 ...

  9. java 中的2个接口 Comparable和Comparator

    像Integer.String这些类型的数据都是已经实现Comparable接口的,所以对这些类型可以直接通过Arrays.sort(...)和Collections.sort(...)方法进行排序. ...

随机推荐

  1. Qt Installer Framework翻译(3-0)

    终端用户使用流程 离线安装和在线安装对终端用户来说是相似的.安装程序将你的应用程序和维护工具一起打包,该工具由包管理器,更新程序和卸载程序组成.用户可以使用维护工具来添加,更新和删除组件.维护工具连接 ...

  2. Oracle GoldenGate 12.3微服务架构指北

    Microservices Architecture introduction Microservices Architecture is a method or approach to develo ...

  3. 为BlueLake主题增加图片放大效果

    fancyBox 是一个流行的媒体展示增强组件,可以方便为网站添加图片放大.相册浏览.视频弹出层播放等效果.优点有使用简单,支持高度自定义,兼顾触屏.响应式移动端特性,总之使用体验相当好. 现在,我们 ...

  4. es6 promise 简单总结

    话不多说,直捣主题. promise用途:异步编程的一种解决方案. 优点:比传统的解决方案——回调函数和事件——更合理和更强大. 三种状态:pending(进行中).fulfilled(已成功)和re ...

  5. linux系统iot平台编程阶段总结

    1.inline内联函数 在C语言中,如果一些函数被频繁调用,不断地有函数入栈,即函数栈,会造成栈空间或栈内存的大量消耗. 为了解决这个问题,特别的引入了inline修饰符,表示为内联函数. 在使用循 ...

  6. requests快速构造请求头的方法

    上图请求头内容,内容多不说,也不确认哪些数据是必须的,网上找到一个懒办法 快速一键生成 Python 爬虫请求头 实战演练 抓取网站:https://developer.mozilla.org... ...

  7. ios---二维码的扫描

    二维码扫描 使用ios的AVFoundation框架实现二维码扫描 第一步:设置相机访问权限:在Info.plist添加Privacy - Camera Usage Description权限 第二步 ...

  8. mac安装了anaconda但是在终端不能使用conda命令

    只需在终端输入如下命令即可 export PATH=~/anaconda3/bin:$PATH

  9. Jenkins环境配置(集成自动化程序)

    一.下载 直接到官网https://jenkins.io/download/  进行下载 二.安装 1.在浏览器地址栏输入:http://loclhost:8081 运行Jenkins,首次进入会提示 ...

  10. DirectX11 With Windows SDK--29 计算着色器:内存模型、线程同步;实现顺序无关透明度(OIT)

    前言 由于透明混合在不同的绘制顺序下结果会不同,这就要求绘制前要对物体进行排序,然后再从后往前渲染.但即便是仅渲染一个物体(如上一章的水波),也会出现透明绘制顺序不对的情况,普通的绘制是无法避免的.如 ...