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

為了賬號安全,請及時綁定郵箱和手機立即綁定

為什么輸入double avg=sum/4;就是26.0而輸入float avg=sum/4f;就是26.25

不懂,他們不是只是精確位數和占用大小不一樣嗎

正在回答

2 回答

涉及(計算)自動轉型,char、byte計算時轉成int(沒有比int范圍更廣的long和精度更高的浮點數參與),其他的就是向精度更高的轉型,int與long計算轉型成long,int與float/double計算轉型成float/double,float與double轉型成double

這里,我想sum應該是個整型吧(int/long),在計算double avg = sum/4; 時sum為int或long,除以4被轉型為int/long類型,然后被賦值給精度更高的double類型,然而整型是沒有浮點數部分的,因此小數部分在后面計算(sum/4)時就已經被丟棄了,只保留了整數部分并賦值給double

而float avg = sum/4f;后面sum/4f時明確指定了除數是一個float類型的浮點數,那么這個計算會被轉型成精度更高的float進行計算(即把sum也作float類型進行除運算),因此結果會保留到float所允許的浮點數精度范圍內

4 回復 有任何疑惑可以回復我~
#1

寂靜的小白 提問者

非常感謝!
2015-03-12 回復 有任何疑惑可以回復我~
#2

寂靜的小白 提問者

真的好高深,但是我居然看懂了!謝謝你
2015-03-12 回復 有任何疑惑可以回復我~
#3

寒蕊

很感謝~
2015-03-25 回復 有任何疑惑可以回復我~

第一個是 (double)(sum/4)

第二個是 (float)((float)sum/(float)4)?

2 回復 有任何疑惑可以回復我~
#1

寂靜的小白 提問者

有什么區別呢?
2015-03-11 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

為什么輸入double avg=sum/4;就是26.0而輸入float avg=sum/4f;就是26.25

我要回答 關注問題
微信客服

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

幫助反饋 APP下載

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

公眾號

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