c++ - 为什么输出这个结果?

浏览:26日期:2023-04-21

问题描述

unsigned short val1 = 0xa500; short val2 = 0xa500; printf('%0xn',val1);//输出a500 printf('%0xn',val2);//输出ffffa500

问题解答

回答1:

因为short的范围是-32768到32767,而0xa500是42240,超过范围了,实际是-23296,所以会按补码来存,低16位的补码是a500,高16位是符号位,-1的补码是ffff,因此一起就是0xffffa500而unsigned short的范围是0到65535,没超范围,所以一切正常

回答2:

当把0xa500赋值给一个2字节变量时,其二进制是1010010100000000,对于这么一个16位二进制,解读为16位无符号整数就是0xa500,解读为16位有符号整数就是-23296(自行根据反补码规则解读)

然后问题来了当你用在printf中以%x输出时,注意,%x意味着输出一个四字节十六进制整数,所以此时你的变量已经被隐式转换到四字节了!

对于正整数,隐式转换就是在前面补0,即变为00000000000000001010010100000000,即0xa500然而对于负数,隐式转换会按照负数补码规则,在高16位填充1,变成11111111111111111010010100000000,即0xffffa500了

回答3:

去学编码基础,有符号类型即便你赋值形式和无符号一样,也得用补码啊,怎么会一样

相关文章: