java 位运算

[size=medium] java 中运算效率最快的算是位运算了,所以我们可以在程序中适当的运用位运算来加快效率。

位运算,实际是 将人类看的懂的十进制先转为 2进制,之后进行位运算。
包含 无符号和有符号。这里简单说下 无符号 位运算,以HashMap 源码中,hash值的计算为例进行分析。[/size]


static int hash(int h) {
h ^= (h >>> 20) ^ (h >>> 12);
return h ^ (h >>> 7) ^ (h >>> 4);
}


[size=medium] 上面这段代码是HashMap 中为了防止出现 重复散列而设计出的一种算法。此算法加入了高位计算,防止低位不变,高位变化导致hash冲突。
此处以 32位为准。[/size]
加入 传值 为 0,则 0 二进制表示为
 00000000  00000000  00000000  00000000 

0 右移 20位,舍弃低位,结果仍未

00000000  00000000  00000000  00000000 


右移 12位 其结果 也仍为
00000000  00000000  00000000  00000000 

h ^= (h >>> 20) ^ (h >>> 12);
此处运算中 0和0 的异或运算
因为 高低位 同为 0 ,所以其结果仍为 0

同理,右移 7位 右移 4位 也仍为 0,其异或运算也是0,所以 0的输出结果为 0.


当传入的值 是 1 的时候,

1 的二进制表示为:
 00000000  00000000  00000000  00000001 

1 右移 20位,舍弃 低位,结果为
00000000  00000000  00000000  00000000 

1 右移 12位,舍弃 低位,结果为
00000000  00000000  00000000  00000000 

表达式 h ^= (h >>> 20) ^ (h >>> 12);
右边 运算 0与0的异或运算为 0,
之后 1和 0 的异或运算为


0--> 00000000 00000000 00000000 00000000
1--> 00000000 00000000 00000000 00000001


其异或 结果为
00000000 00000000 00000000 00000001

同理 按照此思路一次计算下面的值。

直到 传入的值 大于 10的时候,输出的值才不是其本身。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

annan211

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值