JavaScript 将数字存储为 64 位浮点数,但所有按位运算都以 32 位二进制数执行。在执行位运算之前,JavaScript 将数字转换为 32 位有符号整数。执行按位操作后,结果将转换回 64 位 JavaScript 数。
正数:补码=原码; 负数:补码=反码+1;
~运算:反转所有位
以下面题目为例解释
00000000000000000000000000000101 (5)
11111111111111111111111111111010 (~5 = -6)
有符号整数使用最左边的位作为减号。
此处运用补码方法,5的二进制补码和原码相同即
1 00000000000000000000000000000101->
2 反码00000000000000000000000000000101->
3 补码00000000000000000000000000000101
4 取~运算之后11111111111111111111111111010
5 减1得11111111111111111111111111111001
6 除最左边符号位再取反10000000000000000000000000000110
其中 4 5 6是负数得到补码的逆运算,正运算应该为:原码除符号位都取反得到反码,反码+1得到补码。
总结:
当进行别的运算的时候
也需要将所有原码转换成补码,
正数的原码=补码,
负数的补码为反码+1,反码为原码除符号位取反,
之后进行相应运算,(&、|、~、^、移动等)
然后反向求原码,
可以得到最后结果