需要帮助了解按位运算符的用法

时间:2011-08-09 17:50:41

标签: c# bit-manipulation

我继承了一些代码而无法弄清楚它的一部分:

byte[] b = new byte[4] { 3, 2, 5, 7 };
int c = (b[0] & 0x7f) << 24 | b[1] << 16 | b[2] << 8 | b[3];

谁能告诉我们这里发生了什么?

2 个答案:

答案 0 :(得分:20)

基本上它使用big-endian conversion将4字节数组的低31位转换为整数。

因此{0,0,0,1}的字节数组将转换为1; {0,0,1,0}的字节数组将转换为256等。

它通过按位运算符的混合来实现:

答案 1 :(得分:5)

没有在一分钟内完成数学运算所以...为了好玩:
[显示操作顺序的额外括号]

((b[0] & 0x7f) << 24) | (b[1] << 16) | (b[2] << 8) | b[3]

(b[0] & 0x7f) << 24 =  11 0000 0000 0000 0000 0000 0000
b[1] << 16 = . . . . . . . . . . 10 0000 0000 0000 0000
b[2] << 8 = . . . . . . . . . . . . . . . 101 0000 0000
b[3] = .  .  .  .  .  .  .  .  .  .  .  .  .  .  . 0111

现在或者这些在一起,你得到了

0011 0000 0010 0000 0101 0000 0111 = 50,464,007