在javascript中,我们无法在按位运算中评估大于32位。但是在c#中我们可以做到这一点。
以下是示例如果我们尝试运行以下一个浏览器控制台
4294967296& 8589934591
它的返回0但是在C#中它返回 4294967296
我用Google搜索,我发现我们可以使用这一个goog.math.Long来实现大于32位的实现。
但我的问题是,我无法找到样本来实现客户端的逻辑。
任何人都可以帮助我。
提前致谢
答案 0 :(得分:1)
javascript按位64位实现使用goog.math.Long
// goog.provide('goog.math.Long')
var goog = {}; goog.math = {};
var val1 = goog.math.Long.fromString("4611686018427387904");
以下是示例:
<!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。您可以使用Browserify或Webpack将模块捆绑到客户端。
答案 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位按位操作。