我正在将一些传统的Pascal转换为JavaScript。我需要多个两个32位有符号整数。
在下面的示例循环中,一些乘法将导致溢出并将给出负数。这是故意的。我需要在与遗留系统匹配的末尾重现相同的最终数字x。
如何在JavaScript中实现此目的?
以下是一些示例代码:
var x = new Number(some value); // I need this to be a 32-bit signed integer
var y = new Number(some value); // I need this to be a 32-bit signed integer
for (var i=0; i<100; i++) {
x = x * y;
}
return x;
答案 0 :(得分:10)
Javascript的按位运算符实际上将值转换为常规整数。 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators像asm.js这样的事实用来强制类型,你也可以自己做。诀窍是在数字的末尾加上| 0以强制它为32位
function test() {
var x = 255|0; // |0 does the type coercion
var y = 255|0; // not strictly necessary at this var decl but used for explicitness
for (var i=0; i<5; i++) {
x = (y * x)|0; // parens needed because |'s precedence
}
return x;
}
我用一些数字运行它并得到与Firefox中的C相同的结果..没有机会在IE中测试,但我很确定这种行为是在ECMAscript规范中,所以它应该工作
答案 1 :(得分:1)
JavaScript中的数学运算总是以双精度浮点形式完成。你必须编写自己的乘法例程(或在某个地方找到一个)来执行整数数学运算,这将是缓慢或困难(或两者兼而有之)。