javascript按位64位实现

时间:2016-06-18 13:32:04

标签: javascript integer 64-bit bit-manipulation

在javascript中,我们无法在按位运算中评估大于32位。但是在c#中我们可以做到这一点。

以下是示例如果我们尝试运行以下一个浏览器控制台

  

4294967296& 8589934591

它的返回0但是在C#中它返回 4294967296

我用Google搜索,我发现我们可以使用这一个goog.math.Long来实现大于32位的实现。

但我的问题是,我无法找到样本来实现客户端的逻辑。

任何人都可以帮助我。

提前致谢

4 个答案:

答案 0 :(得分:1)

  

javascript按位64位实现使用goog.math.Long

以下是示例:

<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title>Bitmask 64 Bit</title>
    <script type="text/javascript" src="goog.math.long.js"></script>
    <script type="text/javascript">
        var val1 = goog.math.Long.fromString("4611686018427387904"); // 2^62
        var val2 = goog.math.Long.fromString("6917529027641081856"); // 2^61 | 2^62
        var val3 = goog.math.Long.fromString("2305843009213693952"); // 2^61
        var val4 = goog.math.Long.fromString("4611686018427387904"); // 2^62
        document.writeln(val1.and(val2)); // 2^62 & (2^61 | 2^62)  
        document.writeln(val3.or(val4));  // 2^61 | 2^62
    </script>
</head>
<body>
</body>
</html>

使用此库需要许可证。

答案 1 :(得分:0)

我觉得你真的不需要goog.math.long? 只需将其转换为字符串即可拆分。然后继续 AND 操作并重新构建:

var a = 8589934592;
var str = a.toString()
var subNumber1 = parseInt(str.slice(0, str.length - 5));
var subNumber2 = parseInt(str.slice(str.length - 5));
var res1 = (subNumber1 & subNumber1).toString();
var res2 = (subNumber2 & subNumber2).toString();
var res = parseInt(res1.concat(res2));
console.log(res);

答案 2 :(得分:0)

我不确定你是否正在寻找这个,但是你是否正在使用带有npm的google / closure-library。您可以使用BrowserifyWebpack将模块捆绑到客户端。

答案 3 :(得分:0)

我从这个网址得到了线索,但没有使用goog.math.Long。

How to do bitwise AND in javascript on variables that are longer than 32 bit?

这是一个适用于任意大整数的有趣函数:

function BitwiseAndLarge(val1, val2) {
    var shift = 0, result = 0;
    var mask = ~((~0) << 30); // Gives us a bit mask like 01111..1 (30 ones)
    var divisor = 1 << 30; // To work with the bit mask, we need to clear bits at a time
    while( (val1 != 0) && (val2 != 0) ) {
        var rs = (mask & val1) & (mask & val2);
        val1 = Math.floor(val1 / divisor); // val1 >>> 30
        val2 = Math.floor(val2 / divisor); // val2 >>> 30
        for(var i = shift++; i--;) {
            rs *= divisor; // rs << 30
        }
        result += rs;
    }
    return result;
}

假设系统正确处理至少30位按位操作。