dongtao9095 2017-11-29 05:47
浏览 1516

golang将big.Float转换为big.Int

convert big.Float to big.Int, i write code below, but it overflow with uint64, so what's the correct way to cenvert big.Float to big.Int.

package main

import "fmt"
import "math/big"

func FloatToBigInt(val float64) *big.Int {
    bigval := new(big.Float)
    bigval.SetFloat64(val)

    coin := new(big.Float)
    coin.SetInt(big.NewInt(1000000000000000000))
    bigval.Mul(bigval, coin)

    result := new(big.Int)
    f,_ := bigval.Uint64()
    result.SetUint64(f)

    return result
}

func main() {
    fmt.Println("vim-go")
    fmt.Println(FloatToBigInt(float64(10)))
    fmt.Println(FloatToBigInt(float64(20)))
    fmt.Println(FloatToBigInt(float64(30)))
    fmt.Println(FloatToBigInt(float64(40)))
    fmt.Println(FloatToBigInt(float64(50)))
    fmt.Println(FloatToBigInt(float64(100)))
    fmt.Println(FloatToBigInt(float64(1000)))
    fmt.Println(FloatToBigInt(float64(10000)))
}
  • 写回答

2条回答 默认 最新

  • dsxjot8620 2017-11-29 06:07
    关注

    A big int bigger than uint64 will always cause an overflow as uint64 has fixed size. You should use the following method on *Float:

    func (*Float) Int
    

    The changes required would be:

    func FloatToBigInt(val float64) *big.Int {
        bigval := new(big.Float)
        bigval.SetFloat64(val)
        // Set precision if required.
        // bigval.SetPrec(64)
    
        coin := new(big.Float)
        coin.SetInt(big.NewInt(1000000000000000000))
    
        bigval.Mul(bigval, coin)
    
        result := new(big.Int)
        bigval.Int(result) // store converted number in result
    
        return result
    }
    

    Working example: https://play.golang.org/p/sEhH6iPkrK

    评论

报告相同问题?

悬赏问题

  • ¥15 chaquopy python 安卓
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题