※ 引述《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
: 同樣都是大放小,為什麼 整數可以 浮點數不行 = =
: 如果標題取的不好,我再更改 @@
: 謝謝
不好意思回覆這篇多年前的文章
但最近我也被這個問題困擾
有想到一個可能的原因
不知道對不對
也希望板上的高手能為小弟解惑