C语言中的double是最多多少位?

来源:百度知道 编辑:UC知道 时间:2024/05/26 14:13:57
我想知道C语言中的double的整数部分,最多可以有多少位?

双精度实数。
占用字节8
有效数字15~16(因为二进制转十进制问题)
数值范围-1.7*10负308次方~1.7*10的308次方。

当有效数字全部是整数时,即整数有15~16位。
ps:严重同意tanyuguo的:“只考虑有效位数,不考虑整数部分有多少位”。

具体内存中的表示方法参考:http://zhidao.baidu.com/question/15397287.html

double占8个字节(64位)内存空间,最多可提供16位有效数字,小数点后默认保留6位。如全是整数,最多提供15位有效数字。测试代码如下,

#include <stdio.h>
#include <math.h>
int main(int argc, char *argv[])
{
printf("%lf\n",123456789012345678.789);//输出123456789012345680.000000
printf("%lf\n",(double)123456789012345678);//输出123456789012345680.000000
printf("%lf\n",1234567890.1234567);//输出1234567890.123457
return 0;
}

对于double类型数据,通常不能与0直接比较,而是通过其绝对值小于给定的容差值来判断是否满足精度需求,"float.h"头文件往往定义了基本数据类型能够表示的数据的最大值和最小值,比如,
#define DBL_MIN 2.2250738585072014e-308 //宏定义了double类型最小正数