#include<stdio.h>
//#define debug
void main()
{
#ifdef debug
printf("123\n");
#endif
int b = 2.5; //b为整型,值为2 高到低丢失精度
int c = (int)2.5; //c为整型,值为2
float d = b; //d为float,值为2.0
printf("%d\n",b);
printf("%lf\n",b); //类型不同,输出0
printf("%f\n",(float)b);
printf("%d\n",c);
printf("%f\n",c); //类型不同,输出0
printf("%f\n",(float)c);
printf("%d\n",d); //类型不同,输出0
printf("%f\n",d);
printf("%d\n",(int)b);
}
结论:(类型无论高到低还是低到高)
格式化输出printf中,“格式控制字符串”(%d等)中的格式转换符(如d、f、c等),必须与所对应的表达式的数据类型一致,否则输出形式0,即
int对应0
float对应0.000000
string对应空,但lf和f可以混用
类型高到低,精度丢失,是变量赋值的规则,而不是printf格式转换符类型不匹配时的规则。尤其是<math.h>里的函数返回类型都是double