研究javascript中位运算相关资料,对取反位运算很是不理解,不明白取反后为什么不是最大数-目前的值,而是~8=-9,~-8=7?
研究javascript中位运算相关资料,对取反位运算很是不理解,不明白取反后为什么不是最大数-目前的值,而是~8=-9,~-8=7?
~8=-9
8的二进制 11000 =》第一位是符号位,正数1,负数0
按位取反 =》所有位取反,再取补码
11000 取反=》 00111 补码(负数的补码,符号位不动,其它取反+1)=》 01000+1 =》01001(-9)
~-8=7?
-8的二进制 01000 =》第一位是符号位,正数1,负数0
按位取反 =》所有位取反,再取补码
01000 取反=》 10111 补码(正数的补码是其本身)=》 10111(7)
8 回答4.6k 阅读✓ 已解决
6 回答3.3k 阅读✓ 已解决
5 回答2.8k 阅读✓ 已解决
5 回答6.3k 阅读✓ 已解决
4 回答2.2k 阅读✓ 已解决
4 回答2.7k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
因为 ~8 恰好是 -9 在计算机中的表示方式。。。。
32位无符号整数可以表示
0 ~ 2^32-1
的正整数范围,这样可以表示2^32
个整数。当作为有符号数的时候,不是把最高的比特位作为符号位,即
-1
不是直接把000..001
的最高bit置为 1 ,而是使用其-1 + 2^32
=2^32-1
对应的二进制数表示。这种形式叫做补码。一种最快的求负数补码的方式是,其绝对值的二进制,从低位开始,遇到的第一个 1 之前(包括这个1)不变,其他的 1 变 0, 0 变 1。 比如 -4 的补码是, 4 ->00...0100
->11...1100
这样做的好处是,减少运算规则,对于加法和减法,计算机不必区分是不是有符号的。比如 4 位的整形。 有符号的
-5 + 4 = -1
二进制表示是1011 + 0100 = 1111
,而无符号的11+4=15
二进制形式也是1011 + 0100 = 1111
。如果用1101
表示-5
那么有符号加法就是1101 + 0100 = 1111
,这样,人看起来不方便,计算机也不方便。你说的对,去反就是
最大的值-当前的值
这是对于无符号整数来说的。 只是除了>>>
之外,JS 位操作符的返回值,是有符号型的32位整数。