C整数和浮点除法输出

时间:2018-10-28 12:40:50

标签: c integer division

有人可以解释以下代码的输出: 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

2 个答案:

答案 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;
}