某次面试的时候面试官提到
如果将一个对象作为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方法的使用
原文链接如下:
文章非常详细。但也由于过长,所以我这里就写下我看完这篇文章后总结出来的结论吧。
//创建字符串无非下面这两种
String x1 = "我是字符串" //1
String x2 = new String("我是字符串"); //2
String x3 = new String("我是字符串");
x3=x3.intern(); //3
结论
方式1创建字符串相当于先去常量池里找这个内容的字符串是否已存在,如果已存在返回该引用,不存在的话相当于new了一个并放在常量池里返回该引用。
方式2的话每次new都会新建一个String对象
== 比较的是引用对象,equals比较的是字符串内容
第三种方法利用intern的效果就是,无需用equals来比较字符串直接用==就可以,大大提高效率。(因为String对象的equals()方法将会对字符串内容拆解,然后逐个进行比较,如果字符串内容十分大的话,那么这个比较动作则大大降低了性能。)
String x = "我是字符串";
String x2 = new String("我是字符串");
// x2 = x2.intern();
System.out.println(x==x2); //intern开启则为true,否则为false