数据有不同的类型,不同类型数据之间进行混合运算时必然涉及到类型的转换问题.
转换的方法有两种:
自动转换:
遵循一定的规则,由编译系统自动完成.
强制类型转换:
把表达式的运算结果强制转换成所需的数据类型
1 自动转换
自动转换原则
1、占用内存字节数少(值域小
)
的类型,向占用内存字节数多
(
值域大
)
的类型转换
,
以保证精
度不降低
.
2、转换方向:
2 强制转换
通过类型转换运算来实现
(类型说明符) (表达式)
功能:
把表达式的运算结果强制转换成类型说明符所表示的类型
例如:
(float)a; // 把a的值转换为实型
(int)(x+y); // 把x+y的结果值转换为整型
注意:
类型说明符必须加括号
案例
#include <stdio.h>
int main(int argc, char *argv[])
{
//***************强制类型转换之自动转换******************
//参加运算的成员全部变成int类型的参加运算,结果也是int类型的
printf("%d\n",5/2);
//当表达式中出现了带小数点的实数,参加运算的成员全部变成double类型
//参加运算,结果也是double型
printf("%lf\n",5.0/2);
//当表达式中有有符号数 也有无符号数,参加运算的成员变成无符号数参
//加运算结果也是无符号数.(表达式中无实数)
int a = -8;
unsigned int b=7;
if(a + b > 0)
{
printf("a+b>0\n");
}
else
{
printf("a+b<=0\n");
}
//在赋值语句中等号右边的类型自动转换为等号左边的类型
int m;
float n=5.8f;//5.8后面加f代表5.8是float类型,不加的话,认为是double类型
m = n;
printf("m = %d\n",m);
printf("n = %f\n", n); //注意自动类型转换都是在运算的过程中进行临时性的转换,并不会影响自动类型转换的变量的值和其类型
//*************强制类型转换之强制转换************
int x = 10;
int y = 4;
float w;
w = (float)x / (float)y;
printf("w = %f\n", w);
return 0;
}