このコードがコンパイルされないのはなぜですか?
package main
const a = 1.000001
const base = 0
const b = a+base
func main() {
f(b)
}
func f(int) {}
$ go run a.go
# command-line-arguments
./a.go:4: constant 1 truncated to integer
1が切り捨てられたと言っていますか?または、その 1 を切り捨てることはできませんか? それはどの1について話しているのですか?
誰かが上記のコードはコンパイルできないと答えましb
たfloat64
。しかし、なぜこれはコンパイルされますか:
package main
import "fmt"
const a = 1.000001
const b = a-0.000001
func main() {
fmt.Printf("%T %v\n",a,a)
fmt.Printf("%T %v\n",b,b)
f(b)
}
func f(int) {}
$ go run a.go
float64 1.000001
float64 1
? b
はfloat64
here ですが、 に渡すことができますf
。