为什么Java的String中的hashCode()使用31作为乘数?

为什么Java的String中的hashCode()使用31作为乘数?,第1张

为什么Java的String中的hashCode()使用31作为乘数?

根据约书亚·布洛赫(Joshua Bloch)的《有效的Java》(这本书不够推荐,由于对stackoverflow的不断提及,我买了这本书):

选择值31是因为它是奇数质数。如果是偶数且乘法运算溢出,则信息将丢失,因为乘以2等于移位。使用质数的优势尚不清楚,但这是传统的。31的一个不错的特性是乘法可以用移位和减法来代替,以获得更好的性能:

31 * i == (i << 5) - i
。现代VM自动执行这种优化。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4918001.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-12
下一篇 2022-11-12

发表评论

登录后才能评论

评论列表(0条)

保存