二进制操作

按位与:

&1 判断奇偶。

xxx&1 === 1,xxx为奇数;xxx&1 ===0,xxx为偶数。

1的末位是1,其余是0 ,只有奇数&1才为1。

按位取反:

~[1,2,3].indexOf(1)

判断是否在这个数组中,在数组中。返回-1,-2,-3...。没在数组中返回0。

所有正整数的按位取反是其本身+1的负数

所有负整数的按位取反是其本身+1的绝对值

零的按位取反是 -1

二进制数在内存中是以补码的形式存放的。

另外正数和负数的补码不一样,正数的补码、反码都是其本身,既:

正数9:

原码为: 0000 1001

补码为: 0000 1001

反码为: 0000 1001

再例如: -2 

求原码: 1111 0010 (前面4个1表示符号位)

求反码: 1111 1101 (符号位不变,其余各位求反)

求补码: 1111 1110 (符号位不变,末位+1)

所以-2在内存中存放为: 1111 1110

假设要对正数9按位取反——> (~9),计算步骤如下,

原码为 0000 1001,

反码为 0000 1001,

补码为 0000 1001,

对其取反 1111 0110(符号位一起进行取反,这不是反码更加不是最终结果,只是补码的取反仅此而已)

我们还需要把他转换成原码,因为是负数所以进行负数补码到原码的逆运算

先减1得反码: 1111 0101

取反得原码:1111 1010,(反码和原码是一个相对的概念,对反码取反就是原码。取反过程符号位是不变的哦)

前面4个1是符号位,1是负数,既得十进制:-10

参考连接:

原文链接:https://blog.csdn.net/xiexievv/java/article/details/8124108

猜你喜欢

转载自www.cnblogs.com/zhangzs000/p/12952165.html