MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

JavaScript - Convertir un nombre hexadécimal à 24 chiffres en décimal, ajouter 1 puis reconvertir ?

Cette version renverra une chaîne aussi longue que la chaîne d'entrée, de sorte que le dépassement est ignoré dans le cas où l'entrée est quelque chose comme "ffffffff".

function hexIncrement(str) {
    var hex = str.match(/[0-9a-f]/gi);
    var digit = hex.length;
    var carry = 1;

    while (digit-- && carry) {
        var dec = parseInt(hex[digit], 16) + carry;
        carry = Math.floor(dec / 16);
        dec %= 16;
        hex[digit] = dec.toString(16);
    }
    return(hex.join(""));
}

document.write(hexIncrement("55a98f19b27585d81922ba0b") + "<BR>");
document.write(hexIncrement("ffffffffffffffffffffffff"));

Cette version peut renvoyer une chaîne d'un caractère plus longue que la chaîne d'entrée, car une entrée telle que "ffffffff" est transférée pour devenir "100000000".

function hexIncrement(str) {
    var hex = str.match(/[0-9a-f]/gi);
    var digit = hex.length;
    var carry = 1;

    while (digit-- && carry) {
        var dec = parseInt(hex[digit], 16) + carry;
        carry = Math.floor(dec / 16);
        dec %= 16;
        hex[digit] = dec.toString(16);
    }
    if (carry) hex.unshift("1");
    return(hex.join(""));
}

document.write(hexIncrement("55a98f19b27585d81922ba0b") + "<BR>");
document.write(hexIncrement("ffffffffffffffffffffffff"));

J'étais curieux de voir si la suggestion de user2864740 de travailler avec des morceaux à 12 chiffres offrirait un avantage. À ma grande surprise, même si le code semble plus compliqué, il est en fait environ deux fois plus rapide. Mais la première version tourne aussi 500 000 fois par seconde, donc ce n'est pas comme si vous alliez le remarquer dans le monde réel.

function hexIncrement(str) {
    var result = "";
    var carry = 1;
    while (str.length && carry) {
        var hex = str.slice(-12);
        if (/^f*$/i.test(hex)) {
            result = hex.replace(/f/gi, "0") + result;
            carry = 1;
        } else {
            result = ("00000000000" + (parseInt(hex, 16) + carry).toString(16)).slice(-hex.length) + result;
            carry = 0;
        }
        str = str.slice(0,-12);
    }
    return(str.toLowerCase() + (carry ? "1" : "") + result);
}

document.write(hexIncrement("55a98f19b27585d81922ba0b") + "<BR>");
document.write(hexIncrement("000000000000ffffffffffff") + "<BR>");
document.write(hexIncrement("0123456789abcdef000000000000ffffffffffff"));