关于无符号数的原反补码以及整形提升提升

关于无符号数的原反补码以及整形提升:

先简单介绍一下原码、反码、补码:
十进制的数转化为二进制就是原码了,第一位是符号位(1是负、0是正),无符号数就是叫你别管第一位,原码除了符号位全部0变1、1变0就是反码了,反码+1就是补码了,而计算机中的存储及运算都是按补码的,搞定。

再简单介绍一下整形提升:
任何存储空间小于4个字节的变量运算时在cpu都会发生整形提升,补符号位值补至4个字节即32个bit位(是变量的补码进行整形提升)。

好了,分别举一个栗子,一目了然,
下面是一段极其简短的c语言代码

#include <stdio.h>
int main()
{
    
    
	signed char a = -1;//有符号数 字符a
	unsigned char b = -1;//无符号数 字符b
	printf("%d,%d", a, b);//结果为-1,255
	return 0;
}
  1. 输出 signed char a 的过程:
    signed char a 的原码 10000001(char类型是8个bit位)
    反码 11111110
    补码 11111111
    使用 C库函数 printf 将 char 类型变量发送格式化输出到标准输出 stdout 时会先对 char 变量进行整形提升
    整形提升后(提升至32个bit位):
    补码 11111111111111111111111111111111
    反码 11111111111111111111111111111110
    原码 10000000000000000000000000000001(即-1,输出的-1就是这么来的)

  2. 输出 unsigned char b 的过程:
    unsigned char b 的原码 10000001
    反码 11111110
    补码 11111111
    同上,会发生整形提升。
    因为是无符号数所以整形提升的时候当成正数补0。
    整形提升后:
    补码 00000000000000000000000011111111
    反码 00000000000000000000000011111111(无符号数和正数的原码、反码、补码相同)
    原码 00000000000000000000000011111111(即255,输出的255就是这么来的)

感谢阅读~~~

猜你喜欢

转载自blog.csdn.net/weixin_47964723/article/details/114322834