C语言踩坑题:int8_t类型数据的移位或运算
1.分析如下代码,输出结果是多少
#include <stdio.h>
#include <stdint.h>
int main()
{
int8_t a = 0x0D;
int8_t b = 0x9D;
printf("res = 0x%X\n", a << 8| b);
return 0;
}
如果你计算的答案是:0x0D9D,那么恭喜你...........
下边来看DEV运算结果:
2.分析原因
在C语言中,int8_t 是一个8位的有符号整数类型,通常定义为char。当你使用int8_t a=0x0D和int8_t b = 0x9D时,a和b都是有符号的8位整数。
在表达式 a<<8 | b中,a被左移8位,然后与b进行按位或操作;由于a是int8_t类型,左移8位会导致 a的值被提升为 int 类型(通常是32位或64位),然后左移8位。
详细分析如下:
1. a的值是 0x0D左移8位后变为0x0D00;
2. b的值是 0x9D,由于b是int8t类型,且 0x9D在int8t中是一个负数(因为最高位是1),所以当 b 被提升为int 类型时,会进行符号扩展,变为0xFFFFFF9D;
3.然后进行按位或操作:0x0D00 | 0xFFFFFF9D ,结果是0xFFFFFF9D;
4.最后,printf 函数格式化输出时使用 %x,输出的是 0xFFFFFF9D的低16位,即 0xFF9D;