有人可以解释以下代码的输出: http://cpp.sh/9dy44
为什么最后一行总是0.17?
float a = 17, b = 100;
printf("%f\n", 17/100);
printf("%f\n", a/b);
printf("%f\n", 17/b);
printf("%f\n", 17.0f/b);
printf("%f\n", a/100);
printf("%f\n", a/100.0f);
printf("%f\n", 5/100);
输出
0.000000
0.170000
0.170000
0.170000
0.170000
0.170000
0.170000
答案 0 :(得分:2)
这叫做Undefined Behaviour
,不要试图理解为什么会这样,因为顾名思义,它就是undefined
!发生未定义行为的原因是,您尝试打印双精度型,但要传递两个整数。请注意,您还会收到警告:
14:25:警告:格式'%f'期望类型为'double'的参数,但是参数2的类型为'int'[-Wformat =]
将最后一行更改为此:
printf("%f\n", 5.0/100);
它将按预期工作。
答案 1 :(得分:0)
因为您正在将整数相除,而不是尝试打印(整数结果为)浮点值
尝试一下
// Example program
#include <stdio.h>
int main()
{
float a = 17, b = 100;
printf("%f\n", 17.0/100);
printf("%f\n", a/b);
printf("%f\n", 17/b);
printf("%f\n", 17.0f/b);
printf("%f\n", a/100);
printf("%f\n", a/100.0f);
printf("%f\n", 5.00/100);
return 0;
}