理解 C 中的浮点除法
尽管被分配给 double 变量,除法 (3/5) 会导致提供的结果为零由于整数除法而产生的代码。默认情况下,C 将除法表达式中的操作数计算为整数。由于 3 和 5 都是整数,因此它们的除法会产生整数结果,该结果为零。
要执行浮点除法,且结果保持小数精度,至少有一个操作数应该是浮点文字。这迫使编译器将除法视为浮点运算并返回浮点结果。
在原始代码中,为了实现预期的浮点除法,可以将其修改如下:
#include <iostream> int main(int argc, char** argv) { double f = 3.0 / 5; // Change both operands to floating-point literals std::cout << f; return 0; }
通过将一个操作数(在本例中为 3.0)设置为浮点文字,编译器将执行浮点除法,结果将正确反映小数值。
以上是为什么C整数除法结果为零,以及如何实现浮点除法?的详细内容。更多信息请关注PHP中文网其他相关文章!