HashSet:       重写   hashCode和equals方法                                  
      特点:无序,唯一
      底层结构是:
        哈希表:元素为链表的数组。综合了链表和数组的好处
      add方法:底层实际是依赖于HashCode()和equals()方法

HashSet实际用的是HashMap
public HashSet() {
map = new HashMap<>();
}

案例-HashSet存储自定义对象

出现问题:
   重复的元素也被添加了,不能保证元素唯一性

原因:自定义类没有重写HashCode和equals方法;

分析:
    (1) 默认继承Object类的HashCode和equals方法,而Object的HashCode值是通过对象
        的内部地址值转换为一个整数得到的,不同的对象的地址值不同,进而可以知道转换后
        的HashCode值也不可能相同。HashCode值不同就当作不是重复的元素而添加了。
   (2)equals方法默认也是比较地址值,如果不重写equals方法,那么不同的对象
        比较的结果也一定就是false;将会当作不是重复元素而添加了

解决:重写自定义类的HashCode和equals方法

思考:重写HashCode(),那么HashCode值跟什么有关系呢?
      答: 和对象的成员变量值有关系

重写HashCode方法:
      就将对象的成员变量值相加:
             基本类型:直接相加
            引用类型:就加哈希值

// return name.hashCode()+age;
     // 代码优化如下
     return name.hashCode()+age*31;

注意:判断是否是重复元素步骤:
        1-先比较HashCode值:
               1-1:如果HashCode值不同:直接添加
               1-2:如果HashCode值相同:
                    1-2-1:继续判断equals方法:
                                  返回false:添加元素
                                   返回true:放弃添加

对于hashCode和equals方法的理解:(新华字典: 即使是在同一页了,也有可能不是同一个元素)
        同一页:hashCode值
        同一页中同一个元素:hashCode值相同情况下,还要继续采用equals方法判断

二、LinkedHashSet:
      底层数据结构是:链表和哈希表
      链表保证元素有序
      哈希表保证元素唯一

三、TreeSet:

(1)实现Comparable自然排序接口,重写compareTo方法

(2)实现Comparator比较器排序接口,重写compare方法

排序方式:以构造函数确定排序方式
    A 无参构造:自然排序
   class Student implements Comparable<Student>{
       @Override
      public int compareTo(Student s){
       //按年龄排序
       int num=this.age-s.age;
       //隐含条件,年龄相同时,应该继续比较姓名
       int num2=num==0?this.name.compareTo(s.name):num;
       return num2;
      }
  }

B 有参构造:比较器排序 将自定义的比较器类对象作为构造方法的参数
    class MyComparator implements Comparator<Student>{
        @Override
       public int compare(Student s1,Student s2){
          int num=(int)(stu2.getTotal()-stu1.getTotal());
          int num2=num==0?stu1.getName().compareTo(stu2.getName()):num;
          return num2;
        }
    }
   TreeSet<Student> ts=new TreeSet<Student>(new MyComparator());

---------------------------------------------
字符串的比较
int compareTo(String str):

Set常用子类特点的更多相关文章

  1. 集合中Set接口与Collection接口,常用子类TreeSet,HashSet.

    Set接口与List接口的不同之处在于: 不允许有重复的数据. 定义如下: public interface Set<E>extends Collection<E> 主要方法与 ...

  2. Set 接口常用子类及其特点

    Set 集合中元素不可重复,是无序的(存入和取出的顺序是不一样的), Set 接口中的方法和 Collection 接口一致. 常用子类: HashSet : 内部数据结构是哈希表, 是不同步的 Li ...

  3. List 接口常用子类及其特点

    List 常用子类: - Vector: 内部是数组数据结构,是同步的. 增删, 查询都很慢 - ArrayList: 内部是数组数据结构,是不同步的,替代了 Vector,不同步的效率较高. 特点: ...

  4. Map集合,Map常用子类

    Map 集合 1,Collection中的集合,元素是孤立的,向季和忠储存的元素采用一个元素方式储存 2,Map中的集合,元素是成对存在的,每个元素中的集合称为双列集合 3,Collection中的集 ...

  5. Map集合概述和Map常用子类

    概述java.util.Map接口 Map<K,V> 有两个泛型 类型参数:K - 此映射所维护的键的类型V - 映射值的类型 特点:1.Map集合是双列集合,一个元素包含两个值,一个是k ...

  6. Map集合和Map常用子类

    Map集合 java.util.Map<K,V>集合 Map集合的特点: 1.Map集合是一个双列集合,一个元素包含两个值(Key,Value) 2.Map集合中的元素,key和value ...

  7. 系统学习 Java IO (十三)----字符读写 Reader/Writer 及其常用子类

    目录:系统学习 Java IO---- 目录,概览 Reader Reader 类是 Java IO API 中所有 Reader 子类的基类. Reader 类似于 InputStream ,除了它 ...

  8. 阶段1 语言基础+高级_1-3-Java语言高级_04-集合_08 Map集合_2_Map常用子类

    常用的实现类HashMap 它的子类.LinkedHaspMap

  9. 17、Map接口及其常用子类(Hashtable、HashMap、WeakHashMap)

    17.Map接口 Map没有继承Collection接口,Map提供key到value的映射.一个Map中不能包含相同的key,每个key只能映射一个value.Map接口提供3种集合的视图,Map的 ...

随机推荐

  1. 关于vc++ 6.0 编译器,点打开文件时自动关闭

    装好VC++ 6.0后,点打开文件时编译器会自动关闭掉,然后在网上找到各位大神写的资料,果然是因为之前有安装vs2010冲突的缘故,然后http://download.csdn.net/source/ ...

  2. Java线程:新特征-有返回值的线程《转》

      原始文章   在Java5之前,线程是没有返回值的,常常为了“有”返回值,破费周折,而且代码很不好写.或者干脆绕过这道坎,走别的路了.   现在Java终于有可返回值的任务(也可以叫做线程)了. ...

  3. 安装window系统

    安装服务器系统,进入windowpe后将iso中sources,bootmgr,和boot拷贝到C盘,执行bootsect.exe  /nt60  c:,调试froad13的consle win8 改 ...

  4. python之uinttest,用例执行顺序

    unittest单元测试框架, 以test开头的测试用例,默认执行顺序是按照ASC码来执行 如果有类,先排序执行类,在执行类中,再排序用例顺序执行 如果想要按照指定的顺序执行测试用例. 那么就需要用到 ...

  5. IntelliJ IDEA + Maven + Tomcat 本地开发、部署、调试。

    1.maven 下载 解压 配置下 远程仓库( 用阿里云的 比较快).本地仓库 (可以本地C盘建立个文件夹当仓库).环境变量(方便使用maven命令)就可以了. 2.tomcat 下载 解压 配置下 ...

  6. 关于django过滤器的使用

    最近项目中要做分类筛选,其实已经做了这个功能,但是有一个字段是MultiSelectField类型,包含多个值,用户提交的数据是单个值,无法查询出结果, 所以用到了自定义过滤 原代码 class In ...

  7. Oracle学习笔记:11g服务介绍及哪些服务必须开启?

    由于工作环境中oracle版本为10g,不支持行转列函数pivot,特在自己电脑上安装了oracle 11g,但因为不经常使用,便把服务自动启动给关闭了,只在需要使用时手动启动,因此记录一下需要启动的 ...

  8. 20165203 预备作业3 Linux安装及学习

    一.安装虚拟机 1.下载问题:当自己在虚拟机上下载ubuntu时,总是下载好长时间,而且最后下载失败,这让我很苦恼. 解决方案:求助同学后,同学给了我一个中文版官网的网址http://cn.ubunt ...

  9. Hive(六)内置函数与高级操作

    一内置函数 1 数学函数 Return Type Name (Signature) Description DOUBLE round(DOUBLE a) Returns the rounded BIG ...

  10. Web前端开发最佳实践(8):还没有给CSS样式排序?其实你可以更专业一些

    前言 CSS样式排序是指按照一定的规则排列CSS样式属性的定义,排序并不会影响CSS样式的功能和性能,只是让代码看起来更加整洁.CSS代码的逻辑性并不强,一般的开发者写CSS样式也很随意,所以如果不借 ...