理解 Go 中的除法
与其他自动执行浮点除法的编程语言不同,Go 需要显式转换为浮点除法运营。使用整数时,这可能会导致意外结果。
请考虑以下代码:
fmt.Println(3 / 10)
这将输出 0 而不是预期的 0.3。原因是操作数 3 和 10 都是无类型整型常量。根据Go语言规范,如果二元运算的操作数是不同种类的无类型常量,则运算和结果使用列表中后面出现的类型:整数、符文、浮点、复数。在这种情况下,整数出现在浮点之前,因此结果是无类型整数 (0)。
要获得浮点结果,操作数之一必须是浮点常量。考虑以下情况:
fmt.Println(3.0 / 10.0) fmt.Println(3.0 / 10) fmt.Println(3 / 10.0)
所有这些表达式的计算结果将是无类型浮点常量 0.3。通过向任一操作数添加 .0,我们将其显式转换为浮点,从而得到浮点结果。
当除法运算涉及类型化操作数时,类型化操作数的类型决定了表达式的类型。为了确保 float64 结果,类型化操作数应该是 float64。例如:
var i3 = 3 var i10 = 10 fmt.Println(float64(i3) / 10) fmt.Println(3 / float64(i10))
这些表达式会将 int 变量转换为 float64,从而产生 0.3 的 float64 结果。
需要注意的是,像 10.0 和 3.0 这样的数字文字是无类型浮点数-point 常量,而不是 float64。像 i3 / 10.0 和 3.0 / i10 这样的表达式仍然会产生整数 0,因为类型化操作数(i3 和 i10)决定了结果的类型。
以上是Go 如何处理整数除法,如何确保浮点结果?的详细内容。更多信息请关注PHP中文网其他相关文章!