我有这段代码,它基本上接受两个整数并将每个整数相移并相加。但是,添加之后,我得到了一个不正确的值。
我找到了一种解决方法(即通过将移位后的值存储在新的无符号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;
}
答案 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;
^
这是为什么我们应该始终注意编译器警告的示例。