为什么每当我在Visual Studio 2008中编译并运行以下代码时:

double value1 = 10.5;
double value2 = 15.5;
int whole_number = value1 + value2;
Console::WriteLine(whole_number);

我得到的错误值为26而答案是25。

然而,当我在双打中使用静态强制转换时,我得到了正确的答案,即25。

如何解释错误的输出?

有帮助吗?

解决方案

这是绝对正确的。

double value1 = 10.5;
double value2 = 15.5;
int whole_number = value1 + value2; // int whole_number = 26.0;
Console::WriteLine(whole_number);

你会期待什么呢?编译器首先评估右侧,然后隐式转换为int。因此,26.0变为26

在添加之前进行投射,然后您将添加1015,从而导致25:)

其他提示

实际上,在进行自动转换时,您不能依赖浮点数来绕过任何一种方式。如果26.0由26.00005表示,它将四舍五入为26,如果它由25.999995表示,则将四舍五入为25.如果您想确定,请使用round中定义的标准C函数math.h。说因此,26.0变为26 不太正确。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top