golang float 精度

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()即可解决精度问题。

posted @ 2019-05-13 09:16  追逐~~~  阅读(6680)  评论(0编辑  收藏  举报