C语言 double与float数据类型占用的字节数与其数值范围问题

fgdfdgfgfd 2010-04-28 12:30:23
double占用8个字节,而教科书中说它的数值范围是: -10^308~10^308 可按它的字节数换算的话应该是不能大于: -2^(8*8-1)~2^(8*8-1)-1 才对啊。
float也是只占用4个字节,教科书的数值范围是: -10^38~10^38 按字节换算: -2^(4*8-1)~2^(4*8-1)-1
这两个值都没有教科书中的大。为什么啊。
你整型、字符型都能与其字节数换算相等,就这两个不行。
是不是因为它会四舍五入的取前几位有效数字啊,如果是的话是几位呢?
望知者解惑。
...全文
1620 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
z569362161 2010-04-28
  • 打赏
  • 举报
回复
标准规定,对于 float 型,E 后面的阶码的取值范围至少要达到 -37 到 +37。对 double 的规定同样
昵称很不好取 2010-04-28
  • 打赏
  • 举报
回复
可以看看float.h头文件~~
机智的呆呆 2010-04-28
  • 打赏
  • 举报
回复
浮点型的内存布局:
http://blog.csdn.net/Demon__Hunter/archive/2008/12/20/3566232.aspx


浮点型和整形内存布局不一样~~~~~~~~~~~~~~~~
z569362161 2010-04-28
  • 打赏
  • 举报
回复
C 标准要求 float 类型至少要能精确表示到小数点后6位。float 一般是 32 位的。



C 标准规定 double 类型至少要能精确到小数点后 10 位。double 通常是 64 位的。

69,382

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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