关于无符号数的原反补码以及整型提升:
先介绍一下原码、反码、补码:
十进制的数转化为二进制就是原码了,第一位是符号位(1是负、0是正),无符号数就是叫你别管第一位,原码除了符号位全部0变1、1变0就是反码了,反码+1就是补码了,而计算机中的存储及运算都是按补码的,搞定。
再简单介绍一下整型提升:
整型提升是C程序设计语言中的一项规定:在表达式计算时,各种整型首先要提升为int类型再送入cpu执行计算,如果int类型不足以表示则要提升为unsigned int类型;然后执行表达式的运算。–百度百科
我补充一点:是变量的补码进行整型提升,补符号位值补至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;
}
-
输出 signed char a 的过程:
signed char a 的原码 10000001(char类型是8个bit位)
反码 11111110
补码 11111111
使用 C库函数 printf 将 char 类型变量格式化输出到标准输出 stdout 时会先对 char 变量进行整形提升
整形提升后(提升至32个bit位):
补码 11111111111111111111111111111111
反码 11111111111111111111111111111110
原码 10000000000000000000000000000001(即-1,输出的-1就是这么来的) -
输出 unsigned char b 的过程:
unsigned char b 的原码 10000001
反码 11111110
补码 11111111
同上,会发生整形提升。
因为是无符号数所以整形提升的时候当成正数补0。
整形提升后:
补码 00000000000000000000000011111111
反码 00000000000000000000000011111111(无符号数和正数的原码、反码、补码相同)
原码 00000000000000000000000011111111(即255,输出的255就是这么来的)
感谢阅读~~~