4

使用 Emscripten 编译此代码:

#include <stdio.h>
int main() {
unsigned long d1 = 0x847c9b5d;
unsigned long q =  0x549530e1;
printf("%lu\n", d1*q);
return 0;
}

产量(使用-g):

  $d1=-2072208547; //@line 3 "minusmul.c"
  $q=1419063521; //@line 4 "minusmul.c"
  var $2=$d1; //@line 5 "minusmul.c"
  var $3=$q; //@line 5 "minusmul.c"
  var $4=((($2)*($3))|0); //@line 5 "minusmul.c"

js使用(SpiderMonkey 我相信?) 或执行此操作node,我得到结果3217488896。执行本机可执行文件(使用 GCC 编译),我得到3217489085. 如何使用 JavaScript 模拟 x86 无符号 32 位整数乘法?

4

2 回答 2

1

Javascript 使用IEEE-754标准(另请参阅)作为其内部数字表示。这是浮点运算,因此您将不得不提出自己的库函数来模拟大整数的按位运算。存在多个库,例如BigIntBigNumber

于 2012-08-23T23:40:02.917 回答
1

Emscripten 要么不支持精确的 32 位乘法,要么就是一个错误。由于他们在主页上提到他们有 64 位数学的软件仿真,我认为这是一个错误。我发现你可以使用 CHECK_OVERFLOWS 并且它会发现溢出。它似乎并没有“修复”它。要使程序以 CHECK_OVERFLOWS 结束,您需要增加计数,在生成的源代码中标记为“XXX”。

于 2012-08-24T04:20:32.000 回答