如何在javascript中将字符串转换为位掩码?

时间:2010-06-18 16:15:04

标签: javascript google-apps-script

现在,当数字很小时,这很简单,但像“9223372036854775807”这样的数字对于parseInt()来说太大了。

我不确定如何在Google文档脚本编辑器中执行此操作,该编辑器似乎不允许外部类。

1 个答案:

答案 0 :(得分:1)

在这里,在某处使用此脚本,它似乎工作。它背后的想法是它将字符串拆分为8个字符的块,并计算块/ 2,然后将块加起来并得到除以2的结果。

除以2 - 它很容易计算结果。

var maxIntSize = 8;

function divide2(number, addup, depth) {
    var result = "";

    var partLength = Math.min(number.length,maxIntSize); 
    var part = number.substring(0,partLength);

    var partNum = parseInt(part,10);
    var partAdd = (addup==0)?0:(5*Math.pow(10,partLength-1));
    var partRes = Math.floor(partNum/2)+partAdd;
    var partRem = partNum%2;

    result = result + partRes;

    if (depth > 0) {
        for (var i=result.length; i < partLength; i++) {
            result = "0"+result;
        }
    }

    var nextPart = number.substring(partLength, number.length);

    if (partLength < number.length) {
        var res = divide2(nextPart, partRem, depth+1);
        result = result + res.result;
        res.result = result;
        return res;
    } else {
        var res = {result: result, remainder: partRem};
        return res;
    }
}

function toBinary(number) {
    var out = "";

    while (number.length > 1 || number != "0") {
        var res = divide2(number,0,0);
        out = "" + res.remainder + out;
        number = res.result;
    }

    return out;
}

var testNum = "12312312312112312312312312312312312312312312312312312312312312312312312312312312312312312312123";
document.write("bin("+testNum+") = "+toBinary(""+testNum)+"<br/>");

需要划分为块以更快地计算除以2。即使是大量的数据,这个脚本的工作速度也非常快。