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 $
- 1 回答
- 0 關注
- 1025 瀏覽
添加回答
舉報