为什么两个 float64 之间存在差异?
考虑以下 Go 代码片段:
fmt.Println(912 * 0.01) fmt.Println(float64(912) * 0.01)
当你正确理解时第二行打印9.120000000000001,你可能想知道为什么第一行打印 9.12 而没有尾随 ...01。
答案在于 Go 对常量表达式的处理,如规范中所定义:
常量表达式是总是准确评估;中间值和常量本身可能需要比语言中任何预声明类型支持的精度大得多的精度。
因为 912 * 0.01 是一个常量表达式,所以它的计算精度极高。当将此表达式的结果作为参数传递给 fmt.Println() 时,会保持相同的精度。本质上,fmt.Println(912 * 0.01) 的行为就像 fmt.Println(9.12) 一样,其中 9.12 是计算表达式的精确表示。
相反,当您将 912 显式转换为 float64 时在第二行中,浮点乘法的两个操作数都隐式转换为 float64。由于 0.01 无法在 float64 中精确表示,因此会发生精度损失,导致输出中出现 ...01。
因此,结果的差异源于常量表达式求值期间保留的精度和隐含的精度float64(912) * 0.01 涉及的铸造。
以上是为什么 Go 为 `912 * 0.01` 打印 9.12 而为 `float64(912) * 0.01` 打印 9.120000000000001 ?的详细内容。更多信息请关注PHP中文网其他相关文章!