含义:类型不匹配时使用。分为有符号整形和无符号整形两种情况。
有符号整形:以最高位符号位标准提升,即负数补充1,整数补充0
无符号整形:统一补充0
例1:
有以上代码,其输出后a = -1, b = -1,c = 255
原因:在32位系统中,char占1字节,int占4字节,将4个字节的int整形赋给char时,会发生截断。即-1的二进制(数据在内存中以补码的形式存储)补码为11111111111111111111111111111111,赋给char后被截断为11111111。随后在有符号char和signed char中最高位1被认为是符号位,但是在无符号char中最高位1被认为是进制位。之后printf()函数中是以%d,即整形的方式打印,因此会发生整形提升。a, b是有符号整形,以符号位为标准提升,变为11111111111111111111111111111111(补码形式)。但是c是无符号整形,最高位1不是符号位,因此统一补充0,变为00000000000000000000000011111111(补码形式)。此时,a和b是负数,转化为原码后为10000000000000000000000000000001,输出-1,。c被认为是正数,补码和原码相同,因此输出为255
例2:
有以上代码,其输出a = 4294967168
原因:-128作为一个整形,在32位系统中占4字节,二进制原码为1000000000000000000001000000,存储的补码为1111111111111111111111000000,因为char占一个字节,被截断为10000000存储在a中,此时char为signed类型。因为要以%u,即unsigned int的形式打印,因此a发生整形提升,signed类型的char整形提升按符号位提升,变为11111111111111111111111110000000(补码形式)。然后因为要以unsigned int的方式打印,此时a的值被视为无符号类型,因此最高位不再是符号位,而是进制位,此时补码与原码相同,11111111111111111111111110000000就是a的值,此时a输出4294967168
注:char到底是signed char还是unsigned char在c语言中并没有规定,是由编译器决定,但是在大多数编译器中都是signed类型。在内存中见到10000000时该二进制代表的是-128