C - 有符号数和无符号数扩展

C语言标准要求先进行数据大小的转换,之后再进行无符号和有符号之间的转换. C语言中的强制类型转换保持二进制位值不变,只是改变解释位的方式。

将无符号数转换为更大的数据类型时, 只需简单地在开头添加0,这种运算称为0扩展。将有符号数转换为更大的数据类型需要执行符号扩展,规则是将符号位扩展至所需要的位数。扩展的原则是:

  • 有符号的数据类型,在向高精度扩展时,总是带符号扩展
  • 无符号的数据类型,在向高精度扩展时,总是无符号扩展

将一个大的数据类型转换为小的数据类型时,不管是无符号数还是有符号数都是简单地进行位截断。无符号数的数值大小可能因截断而变化,而有符号数不仅数值大小可能变化,符号位也可能发生改变,如8位二进制数00011001(25)转换为4位数截断的结果是1001(-7).


在C语言中,如果一个运算包含一个有符号数和一个无符号数,那么C语言会隐式地将有符号数转换为无符号数。而在汇编语言层面,声明变量的时候,没有 signed 和 unsigned 之分,汇编器统统将输入的整数字面量当作有符号数处理成补码存入到计算机中。

猜你喜欢

转载自blog.csdn.net/happykillerxxx/article/details/84581762