go float 零除编译器错误

jon*_*dev 5 go divide-by-zero

这种行为有何意义?仅打印编译器警告而不是错误不是更有意义吗?

func main() {
var y float64 = 0.0
var x float64 = 4.0 / y
fmt.Println(x)
}
Run Code Online (Sandbox Code Playgroud)

+信息

func main() {
var x float64 = 4.0 / 0.0
fmt.Println(x)
}
Run Code Online (Sandbox Code Playgroud)

prog.go:9:22:除以零

Den*_*ret 4

Golang 数字常量很特殊。它们不直接映射到任何 IEEE754 浮点类型,并且无法存储例如无穷大或 -0。

文档中:

数字常量表示任意精度的精确值并且不会溢出。因此,没有常量表示 IEEE-754 负零、无穷大和非数字值。

这种选择带来了一些力量,因为它减少了常量的溢出:

var x float64 = 1e1000 / 1e999 // yes, this is 10
Run Code Online (Sandbox Code Playgroud)

如果您需要无穷大的值,您可以这样做

var x float64 = math.Inf(1)
Run Code Online (Sandbox Code Playgroud)