一.除法
float a = 10 / 3;
printf("%f\n", a);
double b = 10 / 3;
printf("%lf\n", b);
会出现结果 a = 3.000000,b = 3.000000
只要/两边都是整数,就会先进行整型计算,再将结果转化为3.000000
float c = 10f / 3f;
printf("%f\n", c);
上面这种情况下编译器会报错,因为f前面的值应当为小数。
float d = 10.0f / 3.0f;
printf("%f\n", d);
应当像上面这样写代码。
float e = 10.0f / 3.0;
printf("%f\n", e);
像上面这样也是可以。但会报warning,因为在初始化时将double值赋给了float。把3.0改成3就可以了。
float f = 10.0 / 3.0f;
printf("%f\n", f);
这样还是可以。但会报warning,因为在初始化时将double值赋给了float。把10.0改成10就可以了。
总结来说,就是要保证 / 号两边有一个是所希望的float类型值就可以了。
如果不在小数后面加f,那这个小数就是double类型值。
double g = 10.0 / 3;
printf("%f\n", g);
所以,像上面的代码就是可行的。
总结来说,就是要保证 / 号两边有一个是所希望的double类型值就可以了。
printf("\n\n%lf", 10 / 3);
printf("\n%lf", 10 / 2);
不能直接在printf函数中做跨类型计算,因为printf的输出格式说明符%lf或%d明确规定了所要输出的格式类型,如果不一样会报warning并在有些编译器中打印出0.000000值。
printf("\n%d", 10 / 2);
二、乘法
int h = 10 * 1.11;
printf("\n%d\n", h);
上面这样这样是可以的,得到的结果是整数11,但会有warning,因为第二个数字是double类型数而不是整数。。
double i = 10 * 1.11;
printf("\n%lf\n", i);
上面代码的输出值是11.100000。
(不是跨类型计算但类似)等级提升
#include <stdio.h>
int main()
{
char c = 1;
char d = 2;
printf("%u\n", sizeof(c));
printf("%u\n", sizeof(+c)); //这里相当于 0+c属于运算式
printf("%u\n", sizeof(-c)); //这里相当于 0-c属于运算式
printf("%u\n", sizeof(c + 1));
printf("%u\n", sizeof(c + d));
//上面代码体现等级提升。
return 0;
}
printf(“%u\n”, sizeof(c + d)); 注意最后一行代码,不是跨类型计算