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

C语言 double与float数据类型占用的字节数与其数值范围问题
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
这两个值都没有教科书中的大。为什么啊。
你整型、字符型都能与其字节数换算相等,就这两个不行。 
是不是因为它会四舍五入的取前几位有效数字啊,如果是的话是几位呢?
望知者解惑。

------解决方案--------------------
C 标准要求 float 类型至少要能精确表示到小数点后6位。float 一般是 32 位的。

 

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


------解决方案--------------------
浮点型的内存布局:
http://blog.csdn.net/Demon__Hunter/archive/2008/12/20/3566232.aspx


浮点型和整形内存布局不一样~~~~~~~~~~~~~~~~
------解决方案--------------------
可以看看float.h头文件~~
------解决方案--------------------
标准规定,对于 float 型,E 后面的阶码的取值范围至少要达到 -37 到 +37。对 double 的规定同样