PHP按位AND(&)返回负数

时间:2015-05-22 02:11:46

标签: php bit-manipulation 32-bit

代码:

20407554584

尝试http://phptester.net/,结果(右)将为-1067281896

但在我的网络托管上,它会提供20407554584

有{{1}}的解决方法吗?这是一个32位的限制?

由于

UPDATE /w SOLUTION

1 个答案:

答案 0 :(得分:0)

<强>解

搜索和搜索后,我找到this并在PHP中重新转换

function BitwiseAndLarge($val1, $val2) {

    $shift = 0; 
    $result = 0;
    $mask = ~((~0) << 30); // Gives us a bit mask like 01111..1 (30 ones)

    $divisor = 1 << 30; // To work with the bit mask, we need to clear bits at a time

    while( ($val1 != 0) && ($val2 != 0) ) {
        $rs = ($mask & $val1) & ($mask & $val2);
        $val1 = floor($val1 / $divisor); // val1 >>> 30
        $val2 = floor($val2 / $divisor); // val2 >>> 30

        for($i = $shift++; $i--;) {
            $rs *= $divisor; // rs << 30
        }

        $result += $rs;
    }
    return $result;
}

使用

echo BitwiseAndLarge(5243960811416 & 4040906070209050);