hashcode和equals和== 三者的差异

一、前言

网上存在不少关于hashcode和equals的文章,但是都不够简洁和原始。针对java基础的知识,我们要用回到原点的思想来记忆它,这些东西产生的原因是什么,他们的定义和用处自然就明白,至于后面的差异,则是自然而然就会推导了。

二、定义介绍

首先== 和equals都是用来比较java对象的,而hashcode是java对象运算之后的一个散列值,在java对象比较时并不会使用,但是在集合中会用到。
介绍的顺序应当是== 然后是equals 最后是hashcode。

==符号:

这个符号用来做地址的比较,我们知道一般java对象都是在内存中存放,一个对象只会放在一个特定的内存位置,既然位置都一样,那必然是最严格一样上的同一个对象。可以类比为人的DNA(先不考虑双胞胎)。

equals:

equals方法在Object里的实现其实就是==,也就是默认不改(重写)该方法的时候,equals要求的也是严格一样的同个对象。
但是两个对象比较,理应还有一种是业务意义上的相等,业务中的数据模型简化之后可能只剩几个属性,比如一辆自行车对象,如果我们定义品牌型号批次一致,我们就认为是同一辆自行车,并不会要求到这两个对象在内存中的地址一致,这一种的相等,比==的相等要求略低,可以视为是内容上的相等。
没错,equals的比较,就是针对内容的比较,他们的相等就是按照内容的相等来书写,一个对象不覆盖equals方法,则其比较就升格为完全的相等(地址比较,因为设计者无法知道业务对象要比较什么,只有对象定义的人才会知道)

hashcode

首先要明确,hashcode翻译为散列码,它是一个根据对象属性值计算出来的整形数据,也就是一定是一个可以比较的integer值,这个计算出的值就是将该对象的内容进行一次数字化的编码,方便快速的比较两个不同对象的内容是否不相等。
注意是确认不相等而不能确认相等,若对象的内容不同,则计算的hashcode一定不同,反之却不成立。
计算的原则是尽量让该类下所有不同的对象,都有不同的hashcode,通过特定的算法可以保证绝大多数情况都满足。
其次,这个值在集合中才有用。
以HashSet(key值不重复)或者HashMap(key值不重复,但是value可以追加,如Map<Bike,List<String>)为例子,如果我们以自行车对象为key值。
针对HashSet,什么时候是做key值的替换,什么时候做key值的新增。
针对HashMap,什么时候做key值后的value追加,什么时候做key值的新增。
所依靠的判断,就是这个自行车对象的hashcode值。
执行put的时候,判断新进的对象hashcode是否已有,若是,则set进行替换,map进行追加。
详细见 https://www.jianshu.com/p/fa95b56ccb2b
最后,为方便理解hashcode一样和对象不一样,我们还是以自行车对象为例,简化自行车为型号+批次。 hashcode的计算规则为 型号1+批次2 。 以车甲{2,1} 和车乙(4,0)。 hashcode(甲)=2+12=4 , hashcode(乙)=41+0*2=4。则出现了两个车其实内容不一样,但是hashcode一样的现象。(当然这是因为我们故意降低了hash算法的强度,现实中的散列以31倍乘之后冲突概率很小)

三、结论推导

1、== 是最严格的比较,为真时两者地址一样,实际上就是同一处对象。
2、equals是内容上的比较,两个地址不一样的对象,他们的各项属性可能是一模一样的,根据业务上的需要,可以重新equals方法,使其变为内容上的比较。(若不重写,则默认为==的比较)
3、hashcode,在集合中使用,是对对象各属性(一般是全属性参与计算)计算之后的整型值,两个对象hashcode值一样,他们的内容再所不问,在放置集合的选择时,就被认为同个对象。根据集合是key值是否重复等,继续替换等操作。

hashcode是对各个属性值的再计算,计算算法可能会导致不同属性值运算结果一致。该值在集合中使用。
equals的比较的就是各个属性值拎出来一一比较。(我们讲的都是设计初衷,当然开发者可以随便写)
==比较的就是对象的真实出处。
至于什么==相等 equals什么表现,hashcode一致,另外两个什么表现的结论,我想不用记忆了吧。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容