HashSet的底层实现了解和使用方法

HashSet:实现了Set接口的一个类。

90、  关于 Object 类的 equals 方法的特点

a)  自反性:x.equals(x)应该返回 true

b)  对称性:x.equals(y)为 true,那么 y.equals(x)也为 true。

c)  传递性:x.equals(y)为  true 并且 y.equals(z)为 true,那么 x.equals(z)也应该为 true。

d)  一致性:x.equals(y)的第一次调用为 true,那么 x.equals(y)的第二次、第三次、第 n

次调用也应该为true,前提条件是在比较之间没有修改 x 也没有修改 y。

e)  对于非空引用 x,x.equals(null)返回 false。

91、  关于 Object 类的 hashCode()方法的特点:

a)  在 Java 应用的一次执行过程当中,对于同一个对象的 hashCode 方法的多次调用,

他们应该返回同样的值(前提是该对象的信息没有发生变化)。

b)  对于两个对象来说,如果使用 equals 方法比较返回 true,那么这两个对象的 hashCode值一定是相同的。

c)  对于两个对象来说,如果使用 equals方法比较返回false,那么这两个对象的 hashCode值不要求一定不同(可以相同,可以不同),但是如果不同则可以提高应用的性能。

d)  对于Object类来说,不同的Object对象的hashCode值是不同的(Object类的hashCode

值表示的是对象的地址)。

92、  当使用 HashSet 时,hashCode()方法就会得到调用,判断已经存储在集合中的对象的hash code 值是否与增加的对象的 hash code 值一致;如果不一致,直接加进去;如果一致,再进行 equals 方法的比较,equals 方法如果返回 true,表示对象已经加进去了,就不会再增加新的对象,否则加进去。

93、  如果我们重写 equals 方法,那么也要重写 hashCode 方法,反之亦然。

94、

public class TestSet {   

 

    public static void main(String[] args) {

        

        HashSet set = new HashSet();

        

        System.out.println(set.add("a"));

        set.add("b");

        set.add("c");

        set.add("d");

        System.out.println(set.add("a"));

        

        System.out.println(set);

    }

}

 

 

public class TestSet1 {

 

    public static void main(String[] args) {

        

        HashSet set = new HashSet();

        

        //People p1 = new People("zhangsan");

        //People p2 = new People("lisi");

        //People p3 = new People("zhangsan");

        

        //set.add(p1);

        //set.add(p2);

        //set.add(p3);

        

        //System.out.println(set);

        

        //People p1 = new People("zhangsan");

        

        //set.add(p1);

        //set.add(p1);

        

        //System.out.println(set);

        

        

        String s1 = new String("a");

        String s2 = new String("a");

        

        System.out.println(s1.hashCode()== s2.hashCode());//比较字符串的 hash code

        

        set.add(s1);

        set.add(s2);

        

        System.out.println(set);

        

        

    }

}

 

 

class People{

    

    String name;

    

    People(String name){

        this.name = name;

    }

}


 

String 的方法:hashCode源码:

public int hashCode() {

    int h = hash;

    if (h == 0) {

        int off =offset;

        char val[] =value;

        int len =count;

 

            for (int i = 0; i < len; i++) {

                h = 31*h + val[off++];

            }

            hash = h;

        }

        return h;

}


 

String 对象的哈希码根据以下公式计算:

 s[0]*31^(n-1) +s[1]*31^(n-2) + ... + s[n-1]

实际上String的hash code就是字符串的内容。

95、举例:

public class TestSet2 {

 

    

    public static void main(String[] args) {

        

        HashSet set = new HashSet();

        

        Student s1 = new Student("zhangsan");

        Student s2 = new Student("zhangsan");

        

        set.add(s1);

        set.add(s2);

        

        System.out.println(set);

    }

}

 

 

class Student{

    String name;

    

    Student(String name){

        this.name = name;

    }

    

    public int hashCode(){

        return this.name.hashCode();

    }

    

    public boolean equals(Object obj){

        if(this == obj){

            return true;

        }

        

        if(obj !=null && obj instanceof Student){

            Student s = (Student)obj;

            if(name.equals(s.name)){

                return true;

            }

        }

        return false;

    }

}


 

在使用HashSet时,要重写equalshashCode方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要试HashSet的代码,可以按照以下步骤进行: 1. 首先,了解HashSet底层实现是HashMap。HashSet通过HashMap来实现元素的存储和查找。 2. 在调试HashSet的过程中,可以关注hash()方法。该方法用于判断传入的key是否为空,如果不为空,则调用hashCode方法计算hash值。此外,hash()方法还会对计算得到的hash值进行一些位运算操作,如异或和向右位移,以避免hash碰撞。如果key为空,则返回0。 3. 可以进一步深入HashSet底层源码了解HashSet是如何模拟数组和链表来实现存储结构的。这可以帮助我们更好地理解HashSet的内部机制。 4. 在调试HashSet时,可以对不同情况下的添加元素操作进行观察。可以尝试多次添加元素,包括添加重复元素,以便全面了解HashSet对重复元素的判断和处理方式。 综上所述,要调试HashSet,可以重点关注HashSet底层的HashMap实现,以及hash()方法的调用和处理逻辑。同时,深入了解HashSet的内部结构和添加元素的过程也有助于我们理解和调试HashSet的代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [HashSet集合底层源码解析](https://blog.csdn.net/weixin_73198745/article/details/129649228)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatgptT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值