golang int 轉float 強轉和高精度轉操作
golang int 轉float
方法一:
強轉:
代碼如下:
import "fmt" func main() { var money int money = 1 fmt.Println(float64(money) / float64(100)) }
輸出結果:0.01
方法二:
高精度轉:
代碼如下:
import ( "fmt" "math/big" "strconv" ) func main() { totalAmount := 1 numrator, _ := new(big.Float).SetPrec(uint(1024)).SetString(strconv.Itoa(totalAmount)) denominator := big.NewFloat(100) denominator1 := numrator.Quo(numrator, denominator) fmt.Println(denominator1) }
輸出結果:0.01
補充:golang float32/64與[]byte互轉
網絡協議開發中經常需要將int、float、bool等轉為二進制數據,float32、64 與[]byte處理:
import ( "encoding/binary" "math" ) func Float32ToByte(float float32) []byte { bits := math.Float32bits(float) bytes := make([]byte, 4) binary.LittleEndian.PutUint32(bytes, bits) return bytes } func ByteToFloat32(bytes []byte) float32 { bits := binary.LittleEndian.Uint32(bytes) return math.Float32frombits(bits) } func Float64ToByte(float float64) []byte { bits := math.Float64bits(float) bytes := make([]byte, 8) binary.LittleEndian.PutUint64(bytes, bits) return bytes } func ByteToFloat64(bytes []byte) float64 { bits := binary.LittleEndian.Uint64(bytes) return math.Float64frombits(bits) }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- golang 64位linux環境下編譯出32位程序操作
- Golang通脈之數據類型詳情
- golang中隨機數rand的使用
- go類型轉換及與C的類型轉換方式
- pytorch 如何使用float64訓練