Re: [問題] 預設整數 int 浮點數 double

看板java作者時間8年前 (2016/01/24 22:44), 8年前編輯推噓2(204)
留言6則, 4人參與, 最新討論串2/2 (看更多)
※ 引述《chenhung (小鬍子)》之銘言: : 大家好 : 我有一個問題想要請問 : 書上寫,整數值的預設型別為 int : 讀到整數數值時,會先取得 4byte 的記憶體空間暫時儲存 : 然後再把值複製到指定的變數所代表的記憶體空間儲存 : 若程式碼的數值未超過 int 最大或最小值 : 自然沒問題 舉例: byte a=8 : 浮點數的預設型別為 double : 讀到浮點數值時,會預設取得 8byte 的記憶體空間暫時儲存 : 然後再把值複製到指定的變數所代表的記憶體空間儲存 : 若配置給變數的記憶體空間是 8byte 自然沒問題 : 若小於 8byte 則會產生型別不符的錯誤 : 舉例: float b=3.0 //錯誤 : 我的問題就是:byte a=8,是 預設 int 4byte 放入 byte 1byte,這樣就可以 : 可是 float b=3.0,是預設 double 8byte 放入 float 4byte ,這樣就不行 : 請問是為什麼呢? : byte a=8 //正確 float b=3.0 //錯誤 : 1byte 預設 int 4byte 4 byte 預設 double 8byte : 同樣都是大放小,為什麼 整數可以 浮點數不行 = = : 如果標題取的不好,我再更改 @@ : 謝謝 不好意思回覆這篇多年前的文章 但最近我也被這個問題困擾 有想到一個可能的原因 不知道對不對 也希望板上的高手能為小弟解惑 -------------------------------------------- double 可儲存的小數位數最大為 15,範圍是 -1.8*10^308 ~ 1.8*10^308 float 可儲存的小數位數最大為 7,範圍是 -3.4*10^38 ~ 3.4*10^38 加上浮點數實字預設是 double 型態 所以有可能會發生「float f = 1.12345678;」這樣超過 float 最大小數位數的情形 並且 1.12345678 = 1.12345678*10^0 沒有超過 float 的範圍 所以必須以「float f = 1.1234567f;」表示用 float 來儲存 1.1234567 因此「float b = 3.0;」會編譯錯誤(可能有精準度問題) 而「int a = 8;」則編譯成功(整數沒有精準度問題) -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 122.116.240.120 ※ 文章網址: https://www.ptt.cc/bbs/java/M.1453646683.A.64A.html ※ 編輯: jackblack (122.116.240.120), 01/24/2016 22:50:40

01/26 21:38, , 2F
請問「程式中寫下一個整數時,預設是使用不超過int型態
01/26 21:38, 2F

01/26 21:39, , 3F
長度」的意思是什麼呢?
01/26 21:39, 3F

01/26 21:58, , 4F
整數實字預設不是 int 型態嗎?
01/26 21:58, 4F

01/27 20:48, , 5F
2F 因為用int型態,所以數字長度不能超過int啊。沒衝突啊XD
01/27 20:48, 5F
@jinn: 疑問的點是為什麼 double 指派給 float,與 int 指派給 byte 同樣是大放到小 ,但是 int 指派給 byte、short 就不用像 double 還要改用 float 存值? 後來在《Java in a Nutshell》中找到解答: http://docstore.mik.ua/orelly/java-ent/jnut/ch02_04.htm The one exception to this rule is that you can assign an integer literal (an int value) to a byte or short variable, if the literal falls within the range of the variable. 中文第六版(P.29): 限縮轉型規則有個例外,就是可以把整數字面常數(int 型別)指定給 byte 或 short 型 別變數,但前提必須是該數值不能超過變數型別的值域範圍。 ※ 編輯: jackblack (122.116.240.120), 01/27/2016 23:46:59

01/31 12:39, , 6F
有沒有試過3.0f
01/31 12:39, 6F
文章代碼(AID): #1MfEDRPA (java)
文章代碼(AID): #1MfEDRPA (java)