1、隐式转化
隐式转化规则:由低到高依次是 int--->long---->long long--->float--->double
若运算中有char short 则一并转化为int
1 #include <stdio.h> 2 3 int main() 4 { 5 char a; short b; int c; 6 long long d; float e; double f; 7 8 printf("sizeof(a)=%d\n",sizeof(a));//a占1个字节长度 9 printf("sizeof(b)=%d\n",sizeof(b));//b占2个字节长度 10 printf("sizeof(c)=%d\n",sizeof(c));//c占4个字节长度 11 12 printf("========================\n"); 13 14 printf("sizeof(a+b)=%d\n",sizeof(a+b));//a+b占4个字节长度 15 printf("sizeof(a+c)=%d\n",sizeof(a+c));//a+c占4个字节长度 16 printf("sizeof(b+c)=%d\n",sizeof(b+c));//b+c占4个字节长度 17 18 printf("========================\n"); 19 20 printf("sizeof(d)=%d\n",sizeof(d));//long long型占8个字节长度 21 printf("sizeof(a+d)=%d\n",sizeof(a+d));//char型和long long型一起运算,则提升到long long型,占8个字节长度 22 23 printf("========================\n"); 24 25 c=3; e=5.6; 26 printf("%f\n",c+e);//int型和float型一起运算,则提升到float型,占4个字节,小数点后保留6位数 27 e=10.0; 28 printf("%f\n",e/c);//int型和float型一起运算,则提升到float型,占4个字节,小数点后保留6位数 29 30 printf("========================\n"); 31 32 printf("sizeof(a)=%d\n",sizeof(a)); 33 printf("sizeof(f)=%d\n",sizeof(f));//double型占8个字节 34 35 printf("========================\n"); 36 37 printf("sizeof(d+e)=%d\n",sizeof(d+e));//long long型和float一起运算,则变成float型,占4个字节 38 printf("sizeof(a+f)=%d\n",sizeof(a+f));//char型和double型一起运算,则提升到double型,占8个字节 39 40 41 return 0; 42 }
打印结果:
2、强制转化
格式:( 类型)待转表达式
1 #include <stdio.h> 2 3 int main() 4 { 5 int a=3; int b=10; 6 float c=b/a; 7 printf("%f\n",c);//结果是3.000000 8 9 //若我们想得到3.333333的结果的时候 10 11 float d=(float)b/a;//将b从int型转化到float型,则运算结果以float型的小数表示 12 printf("%f\n",d); 13 14 return 0; 15 }
打印结果:
3、浮点数跟0值比较
1 #include <stdio.h> 2 3 int main() 4 { 5 double tmp=0.0; 6 if(tmp>-0.000001 && tmp<+0.000001)//与-0.000001和+0.000001比较大小 7 { 8 printf("tep==0\n"); 9 } 10 else 11 printf("tep!=0\n"); 12 13 return 0; 14 }
打印结果:
原文:https://www.cnblogs.com/onemusk/p/9481986.html