golang float精度有時會不准確
func main() { fmt.Println(F()) } func F() float64 { f := 10.2 return f * 1e2 }
如上代碼,我們預期得到的結果是1020,而實際得到的結果是1019.9999999999999
package main import ( "fmt" "strconv" ) func main() { fmt.Println(Float2Float(F())) } func F() float64 { f := 10.2 return f * 1e2 } func Float2Float(num float64) float64 { float_num, _ := strconv.ParseFloat(fmt.Sprintf("%.8f", num), 64) return float_num }
調用Float2Float()即可解決精度問題。
