亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Golang 將 float64 轉換為 int 錯誤

Golang 將 float64 轉換為 int 錯誤

Go
瀟湘沐 2021-12-20 19:33:48
將 float 轉換為 int 時如何避免浮點錯誤。例如,下面的代碼打印:0.5499999999999972當我受傷時期望它打印0.55.package mainimport "fmt"func main() {    x := 100.55    fmt.Println(x - float64(int(x)))    }Output:0.5499999999999972
查看完整描述

1 回答

?
九州編程

TA貢獻1785條經驗 獲得超4個贊

您需要了解一些內容:100.55是十進制數(以十進制基數表示)。100.55十進制是一個有限數,正是這樣:100.55。


計算機通常以二進制表示形式存儲數字。該數100.55不能用有限二進制數表示:100.55是二進制表示中的無限數(與1/3不能用有限十進制數表示的原因相同,它是一個無限序列:)0.333333333....。


但是 Go(像任何其他語言一樣)float64使用IEEE-754標準存儲類型,這是一種有限的二進制表示。一個float64值在內存中使用64位來描述數字,其中53位用于描述數字,11位用于指數。


現在當你“說”這個:


x := 100.55

這是一個簡短的變量聲明,它將創建一個名為的新變量,x并從右側表達式推斷其類型,該表達式是一個浮點文字,因此 Go 規范x的類型將為float64. 必須“轉換”浮點文字才能使用 64 位表示(由 指定的規則IEEE-754)。并且由于100.55需要以二進制基數精確表示無限位,因此僅使用 64 位(數字為 53),結果將不會(不能)完全正確100.55(但 IEEE-754 格式的 64 位二進制數是最接近的)到它),即:


x := 100.55

fmt.Printf("%.50f\n", x)


100.54999999999999715782905695959925651550292968750000

所以你已經開始了一個數字 not be 100.55。


你100從中減去(float64(int(x))正好是100.0):


x = x - float64(int(x))

fmt.Printf("%.50f\n", x)


0.54999999999999715782905695959925651550292968750000

你能為這個做什么?真的沒什么。您期望的結果 ( 0.55) 也是二進制表示中的無限數,因此您無法0.55在類型為 的變量中獲得確切的數字float64。


您可以做的是照常使用該數字,但在打印時,請將其四舍五入到您選擇的小數位。最簡單的方法是使用fmt.Printf(), 并使用%f包含精度的動詞指定格式字符串:


fmt.Printf("%.2f\n", x)

結果:


0.55

另一種選擇是避免使用浮點數。例如,如果您要表示美元金額,您可以“乘以”您的所有值,100并將金額表示為美分 (1$*100),這是一個整數。只有當您需要將結果打印為美元時,您才可以打印類似


cents := 10055

fmt.Printf("%d.%d $", cents/100, cents%100)

輸出:


100.55 $


查看完整回答
反對 回復 2021-12-20
  • 1 回答
  • 0 關注
  • 1025 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號