标签:取反 xor hashmap 按位运算 按位取反 现在 绝对值 amp 无符号
虽然在日常中很少能用到Java的位运算符,但是发现在HashMap的源码中发现有>>>运算符,也顺便学习了一下Java中的位运算。
一、& and 按位与,如果两个二进制数的相同位都为1,则得到的新的二进制数该位也为1,否则为0;
| or 按位或,如果两个二进制数相同位至少有一个为1,则得到的新的二进制数该位也为1,否则为0;
^ xor 按位异或,如果两个二进制数相同位不同(一个为1一个为0),则得到的新的二进制数该位也为1,否则为0;
~ not 非,与上面三个不同的是:上面是两个数按位运算得到一个新的数,~是一个二进制数按位取反。
二、>>、>>>和<< 位移运算符
>> 和>>>是右移运算符,区别是>>是有符号右移,>>>数无符号右移。
如果该数为正数,右移后>>和>>>都在高位补0,没有区别;如果该数为负,右移后>>在高位补1,>>>在高位补0。
<<为左移运算符。
符号后面的数字表示移动的位数。
三、补充:原码、反码和补码。
正数的原码、反码和补码相同,都是其二进制表示;
负数:原码为绝对值的二进制表示,然后符号位为1;反码为出符号位各位取反;补码是反码加1.
数字在计算机中以补码的形式储存。
标签:取反 xor hashmap 按位运算 按位取反 现在 绝对值 amp 无符号
原文地址:https://www.cnblogs.com/OnceAgain/p/9160770.html