位移的奇怪行为

时间:2012-06-21 13:26:50

标签: c bit-manipulation

为什么两个 printf 语句输出的值不同?

int main()
{
    int n=10;

    printf("%d\n",(n&0xAAAAAAAA)>>1 + n&0x55555555  ); //prints 0

    printf("%d\n", n&0x55555555 + (n&0xAAAAAAAA)>>1 ); //prints 10

    return 0;
}

http://ideone.com/B33YB

1 个答案:

答案 0 :(得分:14)

由于operator precedence

+的执行时间早于>>

当你改变

(n&0xAAAAAAAA)>>1 + n&0x55555555)

n&0x55555555 + (n&0xAAAAAAAA)>>1)

您实际上正在改变执行操作的顺序。

(n&0xAAAAAAAA)>>1 + n&0x55555555可以重写为(n&0xAAAAAAAA)>>(1 + n&0x55555555),与((n&0xAAAAAAAA)>>1) + n&0x55555555相比有所不同(这是第二行所说的)

+&运算符也一样。

因此,要使输出的输出类似,您需要额外的括号:

int main()
{
    int n=10;

    printf("%d\n",((n&0xAAAAAAAA)>>1) + (n&0x55555555) ); // prints 5
    printf("%d\n",(n&0x55555555) + ((n&0xAAAAAAAA)>>1) ); // prints 5

    return 0;
}

请参阅http://ideone.com/d3mHT