php等效的JavaScript >>>与零填充位运算符右移?
-
27-09-2019 - |
题
我可以知道如何做php >>>吗?此类操作员在PHP中不可用,但在JavaScript中可用。
我刚刚设法发现了以下功能:
function zeroFill($a, $b)
{
$z = hexdec(80000000);
if ($z & $a)
{
$a = ($a>>1);
$a &= (~$z);
$a |= 0x40000000;
$a = ($a>>($b-1));
}
else
{
$a = ($a>>$b);
}
return $a;
}
但是不幸的是,它并不完美。
例如:-1149025787 >>> 0 JavaScript返回3145941509 PHP ZEROFILL()返回0
解决方案 4
我在网周围学习,并提出了自己的Zerofill功能,基于给出的解释。此方法适用于我的程序。
看一看:
function zeroFill($a,$b) {
if ($a >= 0) {
return bindec(decbin($a>>$b)); //simply right shift for positive number
}
$bin = decbin($a>>$b);
$bin = substr($bin, $b); // zero fill on the left side
$o = bindec($bin);
return $o;
}
其他提示
/**
* The >>> javascript operator in php x86_64
* Usage: -1149025787 >>> 0 ---> rrr(-1149025787, 0) === 3145941509
* @param int $v
* @param int $n
* @return int
*/
function rrr($v, $n)
{
return ($v & 0xFFFFFFFF) >> ($n & 0x1F);
}
/**
* The >> javascript operator in php x86_64
* @param int $v
* @param int $n
* @return int
*/
function rr($v, $n)
{
return ($v & 0x80000000 ? $v | 0xFFFFFFFF00000000 : $v & 0xFFFFFFFF) >> ($n & 0x1F);
}
/**
* The << javascript operator in php x86_64
* @param int $v
* @param int $n
* @return int
*/
function ll($v, $n)
{
return ($t = ($v & 0xFFFFFFFF) << ($n & 0x1F)) & 0x80000000 ? $t | 0xFFFFFFFF00000000 : $t & 0xFFFFFFFF;
}
好好享受。
负数的速度是使用小数二进制转换的两倍
function zerofill($a,$b) {
if($a>=0) return $a>>$b;
if($b==0) return (($a>>1)&0x7fffffff)*2+(($a>>$b)&1);
return ((~$a)>>$b)^(0x7fffffff>>($b-1));
我已经对此进行了很多研究,从Stackoverflow和开源项目中收集了11个以上版本,它们都无法使用。但是最后,我找到了解决方案。
有关更多详细信息,请实时演示,测试和示例检查我的问题和答案:
未签名的右移位 /零填充右偏移(Java / JavaScript等效)
function unsignedRightShift($a, $b) {
if ($b >= 32 || $b < -32) {
$m = (int)($b/32);
$b = $b-($m*32);
}
if ($b < 0) {
$b = 32 + $b;
}
if ($b == 0) {
return (($a>>1)&0x7fffffff)*2+(($a>>$b)&1);
}
if ($a < 0)
{
$a = ($a >> 1);
$a &= 0x7fffffff;
$a |= 0x40000000;
$a = ($a >> ($b - 1));
} else {
$a = ($a >> $b);
}
return $a;
}
您的功能不起作用,因为什么时候 $b == 0
, , 表达方式
$a >> -1
将评估,返回0。
假设有32位机器,您可以添加一个特殊情况:
if ($z & $a) {
if ($b == 0)
return $a + 0x100000000;
else {
...
不确定这是否适用于PHP,我设法将其与C#一起使用。
int a, b, result;
//Instead of
result = a >>> b;
//I do
result = (int)((uint)a >> b);
我发现通过调试使用的代码 >>>
将其与我从JavaScript转换的代码的C#版本进行比较。在尝试 b = 0
, ,并使用科学计算器查看不同的十六进制/DEC的结果 >>
和 >>>
由JavaScript制作。什么时候 a
是负的, >>>
实际上使AA无签名。
不确定这是否适用于所有情况,但对于我的情况 >>>
是用于MD5哈希。能够产生相似的输出,我对结果非常满意。
希望有帮助
对于32位(php_int_size == 4)和64位整数(php_int_size == 8):
function SHR
($x, $c)
{
$x = intval ($x); // Because 13.5 >> 0 returns 13. We follow.
$nmaxBits = PHP_INT_SIZE * 8;
$c %= $nmaxBits;
if ($c)
return $x >> $c & ~ (-1 << $nmaxBits - $c);
else
return $x;
}
这对我有用
function RRR($a, $b){
return (int)((float)$a/pow(2,(int)$b));
}
不隶属于 StackOverflow