我正在使用 djb2 算法为字符串生成哈希键,如下所示
hash(unsigned char *str)
{
unsigned long hash = 5381;
int c;
while (c = *str++)
hash = ((hash << 5) + hash) + c; /* hash * 33 + c */
return hash;
}
现在每个循环都有两个大数的乘法,在字符串的第 5 个字符的第 4 个字符经过一段时间后,随着哈希值变得很大,溢出
什么是重构以使哈希值不会溢出并且哈希也正确发生的正确方法是什么