int 和 float型的本质区别

geek2008 2005-06-18 09:52:58
Int 4 bytes ?2,147,483,648 to 2,147,483, 647 (just over 2 billion)

float 4 bytes approximately ±3.40282347E+38F (6?7 significant decimal digits)

同样都是4bytes,为什么range却不一样?请给出具体例子,谢谢。!
...全文
257 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
cat_871017 2005-06-19
  • 打赏
  • 举报
回复
+(-) 1.significand*2^(exponent-127)
cat_871017 2005-06-19
  • 打赏
  • 举报
回复
浮点数是用指数形式表示的
如:0 01000111 00111010111010101010100
第1位是符号sign 后8位是指数exponent+127 最后32位是小数significand

所以真实值是 +(1) 1.significand*2^(exponent-127)

所以范围当然要大的多了
faen 2005-06-19
  • 打赏
  • 举报
回复
float表示的数据不是连续的,而是离散的
helpall 2005-06-19
  • 打赏
  • 举报
回复
int:
00 00 00 00 0
00 00 00 01 1
7F FF FF FF 2^31 - 1 2,147,483,647
80 00 00 00 -2^31 -2,147,483,648
80 00 00 01 -2^31 +1 -2,147,483,647
FF FF FF FE -2
FF FF FF FF -1
float and double
http://babbage.cs.qc.edu/courses/cs341/IEEE-754.html
lhx902 2005-06-18
  • 打赏
  • 举报
回复
float带了小数..int是没有带的。....

62,616

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧