1 回答

TA貢獻1785條經(jīng)驗 獲得超4個贊
您需要了解一些內(nèi)容:100.55是十進制數(shù)(以十進制基數(shù)表示)。100.55十進制是一個有限數(shù),正是這樣:100.55。
計算機通常以二進制表示形式存儲數(shù)字。該數(shù)100.55不能用有限二進制數(shù)表示:100.55是二進制表示中的無限數(shù)(與1/3不能用有限十進制數(shù)表示的原因相同,它是一個無限序列:)0.333333333....。
但是 Go(像任何其他語言一樣)float64使用IEEE-754標準存儲類型,這是一種有限的二進制表示。一個float64值在內(nèi)存中使用64位來描述數(shù)字,其中53位用于描述數(shù)字,11位用于指數(shù)。
現(xiàn)在當你“說”這個:
x := 100.55
這是一個簡短的變量聲明,它將創(chuàng)建一個名為的新變量,x并從右側(cè)表達式推斷其類型,該表達式是一個浮點文字,因此 Go 規(guī)范x的類型將為float64. 必須“轉(zhuǎn)換”浮點文字才能使用 64 位表示(由 指定的規(guī)則IEEE-754)。并且由于100.55需要以二進制基數(shù)精確表示無限位,因此僅使用 64 位(數(shù)字為 53),結(jié)果將不會(不能)完全正確100.55(但 IEEE-754 格式的 64 位二進制數(shù)是最接近的)到它),即:
x := 100.55
fmt.Printf("%.50f\n", x)
100.54999999999999715782905695959925651550292968750000
所以你已經(jīng)開始了一個數(shù)字 not be 100.55。
你100從中減去(float64(int(x))正好是100.0):
x = x - float64(int(x))
fmt.Printf("%.50f\n", x)
0.54999999999999715782905695959925651550292968750000
你能為這個做什么?真的沒什么。您期望的結(jié)果 ( 0.55) 也是二進制表示中的無限數(shù),因此您無法0.55在類型為 的變量中獲得確切的數(shù)字float64。
您可以做的是照常使用該數(shù)字,但在打印時,請將其四舍五入到您選擇的小數(shù)位。最簡單的方法是使用fmt.Printf(), 并使用%f包含精度的動詞指定格式字符串:
fmt.Printf("%.2f\n", x)
結(jié)果:
0.55
另一種選擇是避免使用浮點數(shù)。例如,如果您要表示美元金額,您可以“乘以”您的所有值,100并將金額表示為美分 (1$*100),這是一個整數(shù)。只有當您需要將結(jié)果打印為美元時,您才可以打印類似
cents := 10055
fmt.Printf("%d.%d $", cents/100, cents%100)
輸出:
100.55 $
- 1 回答
- 0 關(guān)注
- 1016 瀏覽
添加回答
舉報