shaoshuai888

哈希值、HashSet、LinkedHashSet

一.哈希值

  1. 哈希值其实就是一个int数字,我们可以把哈希值看成对象的一个标识,Object中的hashCode方法,可以获取到对象的哈希值

  2. Object中的hashCode方法是根据地址值进行计算的

  3. 不过一般哈希值不是根据地址值计算,而是根据对象的属性进行计算,这就需要在Object的子类中重写hashCode方法(idea中一般都用alt+insert快捷键重写,部分电脑用alt+fn+insert快捷键重)

二.HashSet存储自定义对象

  1.存储条件: HashSet存储自定义对象,保证元素的唯一性

  2.满足存储条件分析:

    2.1: 线比较两个对象哈希值(子类中需要重写Object中的hashCode()方法)

    2.2:   如果两个对象哈希值相同,调用equals方法进行比较(子类中需要重写Object中的equals()方法)

  代码演示:

    子类代码也没什么可以演示的,子类中重写的hashCode方法和equals()方法都是快捷键生  成的,若想研究方法内部可在idea中生成方法研究

  HashSet集合存储对象演示:

  

       //创建一个HashSet,用来保存Dog对象
        Set<Dog> set = new HashSet<>();
        set.add(new Dog("哮天犬", 18));
        set.add(new Dog("旺财", 8));
        set.add(new Dog("王可可", 3));
        //添加一个集合中相同的对象,添加不会成功,子类中重写了hashSet方法和equal方法
        set.add(new Dog("旺财", 8));


        //遍历set集合,并打印每一个狗对象
        for(Dog dog : set) {
            System.out.println(dog);    
         }

 三.LinkedHashSet是Set接口的一个实现类

  1. LinkedHash没有延续Set接口的无序特点,它是一个有序的Set集合

  2.  这个类内部出了一个哈希表,还有一个链表,

       链表的作用就是保证LinkedHashSet集合石有序的

  3. Set是无序的,LinkedHashSet就是一个不孝子,没有延续Set接口无序特点(实际上是青出于蓝,   子类更加强大的表现)

  代码演示LinkedHashSet集合是有序的:

    

         Set<String> set = new LinkedHashSet<>();
        //添加元素
        set.add("张三丰");
        set.add("张翠山");
        set.add("莫声谷");
        set.add("张无忌");
        set.add("宋远桥");

        //打印set集合
        System.out.println(set); //[张三丰, 张翠山, 莫声谷, 张无忌, 宋远桥]  ,证实该集合是有序的

 

 

  

    

    

  

posted on 2018-08-30 17:23  shaoshuai888  阅读(224)  评论(0编辑  收藏  举报

导航