第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

Golang 將 float64 轉(zhuǎn)換為 int 錯誤

Golang 將 float64 轉(zhuǎn)換為 int 錯誤

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

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 $


查看完整回答
反對 回復(fù) 2021-12-20
  • 1 回答
  • 0 關(guān)注
  • 1016 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號