【读后感】hashcode和equals方法。 以及捎带提提String使用equals方法和==分别比较的是什么?

时间:2022-03-03 22:05:57

某次面试的时候面试官提到

如果将一个对象作为HashMap的key值,那么这个对象要重写哪些方法。

正好结合HashMap来理解一下Object对象的hashcode和equals方法

之前提到HashMap,如果是插入或者获取一个key的值,会首先拿这个key做一次hash得到一个下标然后再根据这个下标找到头结点进行equals如果不对继续next直到链表的尾端。

所以,可以理解hashcode方法是一个求索引的过程。 equals得到相等的结果,hashcode肯定相等。hashcode相等,equals不一定成立。

那么如果我们将一个对象作为key放入hashmap的话,根据Object的hashcode方法,每次的地址都会不同,永远不会有相同的hashcode,那么就不可能正常操作。hashcode不同,又根本不会走到equals这步。所以必须重写hashcode!

那么如果我们只重写hashcode不重写equals方法呢? 那么的话依旧没办法equals。 所以这俩方法都需要重写,有点像短路且的感觉。。。


看了一篇文章,关于String的两种创建方式(基本类型以及对象),以及intern方法的使用

原文链接如下:

http://blog.csdn.net/wangdong20/article/details/8566217

文章非常详细。但也由于过长,所以我这里就写下我看完这篇文章后总结出来的结论吧。


//创建字符串无非下面这两种
String x1 = "我是字符串"   //1
String x2 = new String("我是字符串");  //2

String x3 = new String("我是字符串");  
x3=x3.intern();                      //3

结论

  1. 方式1创建字符串相当于先去常量池里找这个内容的字符串是否已存在,如果已存在返回该引用,不存在的话相当于new了一个并放在常量池里返回该引用。

  2. 方式2的话每次new都会新建一个String对象

  3. == 比较的是引用对象,equals比较的是字符串内容

  4. 第三种方法利用intern的效果就是,无需用equals来比较字符串直接用==就可以,大大提高效率。(因为String对象的equals()方法将会对字符串内容拆解,然后逐个进行比较,如果字符串内容十分大的话,那么这个比较动作则大大降低了性能。)


String x = "我是字符串";

        String x2 = new String("我是字符串");

// x2 = x2.intern(); 

        System.out.println(x==x2);  //intern开启则为true,否则为false