我们先来关注几个问题。
1、为什么会有整型的截断和整型的提升;
2、什么是整型的截断和整型的提升;
第一个问题提升在计算机处理的时候不够一个整型的数据会提升至一个int 整型来处理,而截断时发生在打印数据的时候,或者比较数值大小的时候。在cpu处理时提升至in型而打印的时候会将其截断变为一个字节数据
第二个问题,打个比方 char a = -12,假如是16位的二进制数,cpu处理时 1000000000001100,由于char 的类型大小是一个字节,在打印时会发生截断,只打印前八位数(有符号的打印),有人会问前八位是00001100那岂不是变成正数?非也,上面的1000000000001100只是个原码,而截断时候是在补码的时候截断的,同时提升也是在补码的时候提升的。正确的应该是这样:
原码 10001100
反码 11110011
补码 11110100
(算术)提升后变成 1111111111110100
由于要打印所以再截断
补码:11110100
原码:10001011
所以十进制是-12;
这样说比较笼统 只是大概了解
我们来看一道题
int main()
{
unsigned char a = 200;
unsigned char b = 100;
unsigned char c = 0;
c = a + b;
printf(“%d %d”, a+b,c);
return 0;
}
首先看a
原码1100 1000(无符号)
补码1100 1000(正数原反补都一样)
同理 b的补码为 0110 0100
在进行a+b时cpu会对a和b的数据进行提升
a变成0000000011001000(假设时16位)
b变成0000000001100100
相加变成0000000100101100(300(b))
前面说了a+b会整型提升为整型
所以a+b=300
c在cpu中时是0000000100101100
但会发生截断变成00101100(0b44)(这里是补码 要转化为原码 要看它的类型 类型是unsigned char)
所以原反补都一样
所以打印c=44;