c中的位移和加法后,变量值不正确

时间:2019-04-18 08:50:49

标签: c

我有这段代码,它基本上接受两个整数并将每个整数相移并相加。但是,添加之后,我得到了一个不正确的值。

我找到了一种解决方法(即通过将移位后的值存储在新的无符号int变量中并将其相加),但是我想了解为什么此方法不起作用:

void change(uint8_t in[3], uint16_t out[2]){
    out[0] = in[0]<<2 + in[1]>>2;
    printf("%u\n",in[0]<<2 ); // outputs 48  --- correct
    printf("%u\n",in[1]>>2 ); // output 1 --- correct
    printf("%u\n",out[0] ); // output 768 --- wrong, I expected 49
}

int main(int argc, char const *argv[])
{
    uint8_t in[3] = {12,6,9};
    uint16_t out[2];
    change(in,out);
    return 0;
}

1 个答案:

答案 0 :(得分:5)

运算符+比移位运算符具有higher precedence。您需要编写:

out[0] = (in[0]<<2) + (in[1]>>2);

不带括号的评估为

out[0] = in[0] << (2 + in[1]) >> 2;

GCC在编译带有以下警告的代码时显示此警告:

test.c:5:23: warning: suggest parentheses around ‘+’ inside ‘<<’ [-Wparentheses]
     out[0] = in[0]<<2 + in[1]>>2;
                       ^

这是为什么我们应该始终注意编译器警告的示例。