【运算时的类型转换】
先看一个例子。请猜测下面的代码的输出是什么?
#include <stdio.h>
int main()
{
unsigned char a = 255;
unsigned char b = 1;
printf("%d %d %d %d\n", (unsigned char)(a + b), (int)(a + b), a + b, (unsigned char)a + (unsigned char)b);
return 0;
}
答案是0 256 256 256。若答对,下面的内容可无视 :D
解释:
基本知识点
1、整数间的运算会被转换成int类型间的运算。
2、浮点数间运算会被转换成double类型间的运算。
3、变参函数的不定实参都是或被转换成int类型的。
那么,a+b计算式自动发生的类型转换就是:(int)((int)a+(int)b),a+b的结果是int类型的256。第一个输出为0是因为被unsigned char截了一下。这样,输出结果就容易理解了。
【有符号数的类型转换】
#include <stdio.h>
int main()
{
signed char a = 255;
printf("%d %d", (unsigned char)a, (unsigned int)a);
return 0;
}
答案是 255 -1。
signed/unsigned决定了位扩展规则,signed按照最高位扩展,unsigned进行0扩展。
(unsigned char)a告诉编译器a为unsigend类型的11111111,最后转int时进行0扩展,成为 00000000 00000000 00000000 11111111,就是256。
(unsigned int)a时a是signed类型的,转为 11111111 11111111 11111111 11111111,再转为int就是-1了。