golang float精度有时会不准确

func main() {
    fmt.Println(F()) 
}

func F() float64 {
    f := 10.2
    return f * 1e2
}

如上代码,我们预期得到的结果是1020,而实际得到的结果是1019.9999999999999

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。
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()即可解决精度问题。

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄