SortedSet

 * TreeSet是SortedSet接口的实现类,TreeSet底层是一个TreeMap,相当于TreeMap中的key。

 * SortedSet集合是如何实现自动排序的呢?

    - TreeSet集合在添加元素的时候会调用已添加元素(类)的 compareTo()方法 (U1.compareTo(U2))方法底层是一个do..while()循环。

    - 如果将compareTo()方法固定返回0 (return 0),那么就会出现只能添加一个数据的结果,因为这样的话表示后面的元素和第一个元素是相等的,而TreeSet集合是不能重复的。

    - 所有可以排序的类,都实现了java.lang.Comparable接口。

    -  Comparable接口中只有一个方法: int conpareTo(T o)

           返回 0,   表示this == obj

           返回正数,表示this > obj

           返回负数,表示this < obj

    - 自己写的类需要实现Comparable接口,然后重写compareTo()方法,才能实现自动排序
  • 代码

            package com.shige.Collection.Set.SortedSet;
    
            import java.util.Iterator;
    import java.util.SortedSet;
    import java.util.TreeSet; public class SortedSetTest02 {
    public static void main(String[] args) { // 创建集合
    SortedSet users= new TreeSet();//父类引用指向子类对象 //创建用户的对象
    User user1=new User(88,"CBA");
    User user2=new User(23,"BAC");
    User user3=new User(43,"ABC"); //添加元素
    users.add(user1);
    users.add(user2);
    users.add(user3); // 遍历输出集合中的元素
    Iterator iterator=users.iterator();
    while(iterator.hasNext()){
    Object user=iterator.next();
    System.out.println(user); // 按照年龄从小到大排序输出
    } } } // 用户类
    class User implements Comparable{ //实现一个接口,就要重写接口中的所有方法
    int age;
    String name; User(int age,String name){
    this.age=age;
    this.name=name;
    } public String toString(){
    return "User[age: "+age+"name: "+name+"]";
    } // 重写Comparable接口中的compareTo方法
    @Override
    public int compareTo(Object o) { // 用年龄age 比较
    /*
    int age1=this.age;
    int age2=((User)o).age; //将O 转换为 User
    return age1-age2; */ //用name字段进行排序,因为String本身就实现了compareTo()方法,所以直接调用即可
    return this.name.compareTo(((User)o).name); }
    }

Day09_45_Set集合_SortedSet02的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. .Net多线程编程—并发集合

    并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...

  3. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  4. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  5. java基础_集合List与Set接口

    List接口继承了Collection的方法  当然也有自己特有的方法向指定位置添加元素   add(索引,添加的元素); 移除指定索引的元素   remove(索引) 修改指定索引的元素   set ...

  6. Java基础Collection集合

    1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:

  7. 轻量级“集合”迭代器-Generator

    Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...

  8. Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合

    今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...

  9. 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)

    在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...

随机推荐

  1. Vulhun-y0usef靶机通关

    Vulhub-y0sef靶机通关 安装靶机环境,下载地址:https://www.vulnhub.com/entry/y0usef-1,624/ 网络模式:桥接 目标:user.txt和root.tx ...

  2. eclipse中将项目加载到tocat报错:Tomcat version 6.0 only supports J2EE 1.2, 1.3, 1.4, and Java EE 5 Web modules

    第一种解决方法:只需要找到导入项目的配置文件即可,举个栗子:D:\公司\iptv_gx\iptv_gx\.settings\org.eclipse.wst.common.project.facet.c ...

  3. Java Socket编程基础及深入讲解

    原文链接:https://www.cnblogs.com/yiwangzhibujian/p/7107785.html 原文写的特别好,非常详细,但是禁止转载,那我就不再复制粘贴了! socket实现 ...

  4. the import java.util cannot be resolve

    重新配置一下build path 的jre,如果不行的话就重新设置jre(在add library中installed JREs)

  5. WPF -- 一种圆形识别方案

    本文介绍一种圆形的识别方案. 识别流程 判断是否为封闭图形: 根据圆的方程,取输入点集中的1/6.3/6.5/6处的三个点,求得圆的方程,获取圆心及半径: 取点集中的部分点,计算点到圆心的距离与半径的 ...

  6. Python3.x 基础练习题100例(41-50)

    练习41: 题目: 模仿静态变量的用法. 程序: def varfunc(): var = 0 print('var = %d' % var) var += 1 if __name__ == '__m ...

  7. 如果要是把标记为2的那一行Lable1.Text改为其他的Lable显示执行代码

    转: 如果要是把标记为2的那一行Lable1.Text改为其他的Lable显示执行代码 如图,程序很简单,文件路径也没问题,为什么会报错,百思不得其解?[url]https://book.douban ...

  8. 微信小程序自定义头部导航栏

    <!--index.wxml--> <view> <navbar id='index_header' background='{{background}}' pageNa ...

  9. pytorch(15)损失函数

    损失函数 1. 损失函数概念 损失函数:衡量模型输出与真实标签的差异 \[损失函数(Loss Function): Loss = f(\hat y,y) \] \[代价函数(Cost Function ...

  10. WPF中Popup上的textbox无法切换到中文输入法

    As Marco Zhou has said in the msdn forum (http://social.msdn.microsoft.com/Forums/en-US/wpf/thread/b ...