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

作者: jackblack   2016-01-24 22:44:39
※ 引述《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
: 同樣都是大放小,為什麼 整數可以 浮點數不行 = =
: 如果標題取的不好,我再更改 @@
: 謝謝
不好意思回覆這篇多年前的文章
但最近我也被這個問題困擾
有想到一個可能的原因
不知道對不對
也希望板上的高手能為小弟解惑
作者: jej (晃奶大馬桶)   2016-01-26 20:20:00
作者: jackblack   2016-01-26 21:38:00
請問「程式中寫下一個整數時,預設是使用不超過int型態長度」的意思是什麼呢?整數實字預設不是 int 型態嗎?
作者: jinn (阿昌)   2016-01-27 20:48:00
2F 因為用int型態,所以數字長度不能超過int啊。沒衝突啊XD
作者: longlongint (華哥爾)   2016-01-31 12:39:00
有沒有試過3.0f

Links booklink

Contact Us: admin [ a t ] ucptt.com