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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM