在位掩码

时间:2017-01-12 02:49:47

标签: php bitmask

我有这样的位掩码:

$mask = 0;
$mask |= 1 << 2;
$mask |= 1 << 9;

print decbin($mask);

结果是1000000100这就是我想要的。我只是想知道,有没有办法在一次操作中启用第2位和第9位?所以它看起来像:

$mask = 0;
$mask |= 1 << (... enable 2 and 9 ...);

print decbin($mask);

1 个答案:

答案 0 :(得分:0)

这给出了相同的结果:

print decbin(1 << 2 | 1 << 9);
  • 1 << 2会产生4
  • 1 << 9会产生512
  • 512 + 4 = 516
  • decbin(516) = 1000000100

现在这不是通常的||声明,您正在执行以下操作:

101001 | 010110 = 111111
41     + 22     = 63

所以在Laymen的术语中,你要合并价值观。

你基本上可以把它放在一个函数中:

function bit_shiftlist(array $nums = [], bool $left = true){
  $ret = 0;
  foreach($nums as $value){
    $ret += $left ? 1 << $value : 1 >> $value;
  }

  return $ret;
}

$mask = bit_shiftlist([2, 9]);

var_dump($mask);       // 516
var_dump($mask ^ 512); // 4
var_dump($mask ^ 4);   // 512
var_dump($mask & 4);   // 4
var_dump($mask & 8);   // 0 - unexisting bit in both value 512 and 4.