我正在将一些代码从 javascript 重写为 php,它应该可以正常工作。
即使用按位 OR计算出来,javascript 也会比较 32 位表示的数字。现在有一个向左移位的问题。
js 30 << 30 возвращает -2147483648
php 30 << 30 возвращает 32212254720
好的,前 32 位,,32212254720 % (2 ** 32)
我们得到2147483648
,几乎就像 js 的结果。
尝试重新创建 js 逻辑,二进制表示中的数字 30
11110
00000000000000000000000000011110
我左移 30 位,我得到
00000000000000000000000000011110000000000000000000000000000000
我留下 32 位
10000000000000000000000000000000
转换为十进制
2147483648
但是 js 中的减号是从哪里来的呢?
附言
谢谢大家的帮助,我写了3个函数| << >>>
,然后我找到了一个现成的库https://github.com/simaguo/javascript-bitwise-operators
从离散数学的课程中,我记得:
为了在计算机内存中写入数字,使用了不同的二进制代码系统......有 3 种类型:
1) 直接 2) 反向 3) 附加(代码)
您的计算机使用二进制补码来写入数字。这不是常规的二进制代码,如果第一个符号是1,那么这是一个负数(即以符号1开头的数字,负数)
顺便说一句,您在知识方面遇到了一个非常有用的错误)现在您知道更多,我的建议,除了学习语言之外,请考虑您的计算机是如何工作的(这绝不是说明,只是建议)))好运气!
JavaScript 中的位运算符在其二进制表示中对 32 位整数进行操作。
二进制形式的数字
30
是0b00000000000000000000000000011110
(0b
- 这只是一个前缀,表示在它以二进制形式写入之后给出的数字。因此,在三十二位表示中,最左边的数字0
(紧随其后0b
,如果从右边算起,则为三十秒!) - 对应于+
前缀后面的数字符号)。我们将这个数字
30
向左移动一个位置30 << 30
,我们得到十进制形式-2147483648
和二进制(32 位)0b10000000000000000000000000000000
,其中最高位(在前缀之后0b
)是 1,对应于减号。您对有符号整数执行操作。第一位是符号。在 Javascript 中,操作
js 30 << 30
返回10000000000000000000000000000000
- 反向代码中的这个数字(你在上面写的)对应-2147483648
于小数。在php中你有一个64位的字,所以你得到一个二进制数,第一位是零,000000000000000000000000000011110000000000000000000000000000000
对应32212254720
于十进制数。仔细检查使用 Windows 程序员的计算器很方便。
如果要在 Javascript 中执行这样的操作,则需要一个 64 位整数。使用来自闭包库的node-int64或goog.math.Long.html