Java一段代码看不明白,在线等

staticinthash(inth){//ThisfunctionensuresthathashCodesthatdifferonlyby//constantmulti... static int hash(int h) {
// This function ensures that hashCodes that differ only by
// constant multiples at each bit position have a bounded
// number of collisions (approximately 8 at default load factor).
h ^= (h >>> 20) ^ (h >>> 12);
return h ^ (h >>> 7) ^ (h >>> 4);
}
展开
 我来答
百度网友9c743b7
推荐于2018-04-11 · TA获得超过925个赞
知道小有建树答主
回答量:360
采纳率:100%
帮助的人:315万
展开全部
保证hashCode 不同的算法,很多人都研究这个算法,算法很多
这个怎么保证的我不知道
但是我可以给你解释下算式
int 是4位byte的 4*8=32bit 一也注意到了12+20=32
h ^= (h >>> 20) ^ (h >>> 12);意味着h=h的前12位不变+中间的8位位中间的8位和前8位异或值+后12位为后12位和前间12位和9-20位的异或值(+不是加法是连接,一共32位)
h ^ (h >>> 7) ^ (h >>> 4); 之后再用类似的方式
新h=前4位不变+前3位和5-7位异或值+前25位和后25位和4-28位的异或值
梦崖紫蝶
推荐于2016-04-28 · TA获得超过1092个赞
知道小有建树答主
回答量:915
采纳率:0%
帮助的人:253万
展开全部
h>>>20是无符号右移运算,就是将int类型的h的二进制数字位往右移动,左边移出来的空位补上0。
h ^= (h >>> 20) ^ (h >>> 12);即为h = h ^ ((h >>> 20) ^ (h >>> 12));按位异或运算。如果h和((h >>> 20) ^ (h >>> 12))仅当两个对应的二进制位不相同时,结果为1;否则结果为0。下面的return就不用说啦。。。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wo940080073
2012-07-27 · TA获得超过100个赞
知道小有建树答主
回答量:121
采纳率:0%
帮助的人:79.2万
展开全部
移位运算符。。。。不懂!飘过。。。。。。。。。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式