为什么Java String哈希函数乘数为31?

开发 前端
在实际应用中,使用 31 作为乘数可以提供良好的哈希值分布和计算速度。当然,也可以使用其他质数作为乘数。例如,37 和 43 也是不错的选择。

哈喽,大家好,我是了不起。

今天给大家介绍一个底层数字问题——为什么Java String哈希函数乘数为31?

1、源码重现

图片

在这个实现中,31 被用作乘数。那么,为什么选择 31 作为乘数呢?

2、降低哈希冲突

31 是一个质数,相信大家学过数学的,质数是这样定义的:

指在大于1的自然数中,除了1和它本身以外没有任何正因数的自然数。

在哈希函数中,使用质数作为乘数可以提高哈希值的分布均匀性。如果使用非质数作为乘数,那么哈希值的分布可能会出现偏斜。

例如,如果使用 10 作为乘数,那么所有以 5 为尾数的字符串的哈希值将是相同的。这会导致哈希冲突的可能性增加。

3、提高哈希计算速度

在 Java 中,int 类型的变量占用 32 位。

31 是一个奇数,因此 31 * i 的结果可以只使用 31 位来表示。这意味着在计算哈希值时,可以使用位运算来代替乘法运算。

位运算比乘法运算要快得多。

因此,使用 31 作为乘数可以提高哈希计算速度。

4、31是一个良好的折中方案

在实际应用中,使用 31 作为乘数可以提供良好的哈希值分布和计算速度。当然,也可以使用其他质数作为乘数。例如,37 和 43 也是不错的选择。

但是,31 是一个相对较小的质数,因此它在计算速度方面具有优势。此外,31 也是一个常用的质数,因此在许多其他哈希函数中也得到了使用。

当然,31 并不是一个完美的乘数。在某些情况下,使用其他质数可能会更好。但是,对于大多数应用程序来说,31 都是一个不错的选择。

责任编辑:武晓燕 来源: Java技术指北
相关推荐

2021-04-08 11:46:41

String hashJava代码

2024-11-07 08:47:53

2014-11-21 10:50:26

JavaString

2023-10-10 08:24:12

2023-12-20 08:11:02

Redis节点通信

2015-10-12 08:56:27

Java不可变

2015-11-23 10:09:30

Java

2020-07-22 07:55:12

Python开发函数

2024-04-25 08:21:36

Java对象计数法

2021-04-29 10:08:10

数据结构哈希表

2023-02-13 08:02:08

哈希函数哈希表搜索树

2010-12-06 16:47:53

金山卫士金山开源

2023-03-30 09:10:38

Linux打包

2021-07-19 09:58:22

Pythonprint函数

2020-09-21 06:10:47

Python lambda匿名函数

2020-08-16 11:29:12

Python函数开发

2024-11-15 10:53:56

Java编程语言

2021-04-26 20:44:59

Nacos方法String.inte

2021-01-22 15:31:47

JavaSwitchString

2011-12-30 15:20:29

点赞
收藏

51CTO技术栈公众号