隐式类型转换
整型、实型和字符型数据之间可以混合运算。例如:
10 + ’a’ + 1.5 - 8765.1234 * ’b’
不同数据类型之间运算会进行自动类型转换,基本的转换规则如下:
自动类型转换比较简单,所以不做详细解释,只要记住上面的规则就可以。
强制类型转换
一般形式:(类型名)(表达式)
例
(int)(x + y)
(int)x + y
(double)(3/2)
(int)3.6
说明:强制转换得到所需类型的中间变量,原变量类型、变量值保持不变
较高类型向较低类型转换时可能发生精度损失问题
#include <stdio.h>
main()
{
float x;
int i;
x=3.6;
i=(int)x;
printf(“x=%f,i=%d”,x,i);
}
结果:x=3.600000,i=3
类型间转换
例如
int a = 2147483648;
printf("%d",a);
这样赋值后,输出变量a的值并非预期的2147483648,而是-2147483648,原因是2147483648超出了int类型能够装载最大值,数据产生了溢出。如果换一种输出格式控制符,代码如下所示:
printf("%u",a);
输出的结果就是变量a的值,原因是%u是按照无符号整型输出的数据,而无符号整型的数据范围上限大于2147483648这个值。
当把占字节较小的数据赋值给占字节较大的数据时,可能出现以下两种情况。
第1种情况,当字节较大数是无符号数时,转换时新扩充的位被填充成0
char b = 10;
unsigned short a = b;
printf("%u",a);
这样赋值后,变量a中输出的值是10
当字节较大数是有符号数时,转换时新扩充的位被填充成符号位
char b = 255;
short a = b;
printf("%d",a);
这样赋值后,变量a输出的值是-1,变量a扩充的高8位,根据变量b的最高位1都被填充成了1,所以数值由正数变成了负数,因为变量a的最高位符号位是1,至于为什么16个1表示的是-1,涉及到二进制数的原码和补码问题,这个以后我们再谈。