使用微芯片XC8,我有一个构造
int16_t test;
uint8_t msb = 0xff;
uint8_t lsb = 0xf4;
uint8_t hyst = 0xff;
test = ((((int16_t)msb)<<8) + (int16_t)lsb) + (int8_t)hyst);我希望测试结果是-13 (oxFFF3),因为我使用了有符号数字,但它被计算为0xF3。
为什么?
编辑:尝试了一下,结果和我预期的一样。
发布于 2015-11-25 21:47:32
正如Olaf正确指出的那样,如果int的宽度为16,则移位操作可能没有定义的行为,因为您要将一位移位到int16_t的符号位。那么你的代码就是错误的,你不能推断出任何关于你的平台可能实现的价值。
如果int较大,则表达式一切正常,您只需将适合int的正值相加即可。但是由于初始化,结果值将被转换回int16_t,这导致“实现定义的”转换或信号的上升。因此,你应该检查你的编译器文档,你的平台在这些情况下做了什么,如果可以的话,避免它可能是一个好主意。
发布于 2015-11-25 22:25:31
评论中的OK
int16_t test;
uint8_t msb = 0xff;
uint8_t lsb = 0xf4;
uint8_t hyst = 0xff;
test = (int16_t)(((uint16_t)msb)<<8) + (uint16_t)lsb) + (int8_t)hyst;解决了问题。谢谢你们!
https://stackoverflow.com/questions/33917962
复制相似问题