作者jackblack ()
看板java
標題Re: [問題] 預設整數 int 浮點數 double
時間Sun Jan 24 22:44:39 2016
※ 引述《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
→ jackblack: 請問「程式中寫下一個整數時,預設是使用不超過int型態 01/26 21:38
→ jackblack: 長度」的意思是什麼呢? 01/26 21:39
→ jackblack: 整數實字預設不是 int 型態嗎? 01/26 21:58
推 jinn: 2F 因為用int型態,所以數字長度不能超過int啊。沒衝突啊XD 01/27 20:48
@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
推 longlongint: 有沒有試過3.0f 01/31 12:39