Re: [問題] 預設整數 int 浮點數 double
※ 引述《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 20:20, , 1F
01/26 20:20, 1F
→
01/26 21:38, , 2F
01/26 21:38, 2F
→
01/26 21:39, , 3F
01/26 21:39, 3F
→
01/26 21:58, , 4F
01/26 21:58, 4F
推
01/27 20:48, , 5F
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
01/31 12:39, 6F
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 2 之 2 篇):
java 近期熱門文章
PTT數位生活區 即時熱門文章