摘要: 前提: 偶然的机会看到了大神的一篇博客,介绍的是hashCode()方法里为什么要用31这个数字作为生成hashCode的乘数。hashCode我在比较自定义类时曾经用到过 - 由于java默认比较的是类的地址值,每个对象一定是不同的,所以重写了hashCode()和equals()方法 ,这样就会 阅读全文
posted @ 2018-01-27 20:13 阿拉巴洞 阅读(6442) 评论(1) 推荐(3) 编辑
摘要: 某天,我在写代码的时候,无意中点开了 String hashCode 方法。然后大致看了一下 hashCode 的实现,发现并不是很复杂。但是我从源码中发现了一个奇怪的数字,也就是本文的主角31。这个数字居然不是用常量声明的,所以没法从字面意思上推断这个数字的用途。后来带着疑问和好奇心,到网上去找资 阅读全文
posted @ 2018-01-27 18:42 阿拉巴洞 阅读(501) 评论(0) 推荐(0) 编辑