打印长双变量的所有十进制数字

Print all decimal digits of long double variable

本文关键字:十进制数字 变量 打印      更新时间:2023-10-16

我发现我的机器上的double类型对应于这篇维基百科文章,long double对应于此文本:x86扩展精度格式。

这就是为什么floor(52/log2(10))或 15 位数字的double应该是正确的,floor(63/log2(10))或 19 位数字的long double是可信的。

代码:

int main()
{
    double d=0.1;
    long double ld=0.1;
    std::cout.precision(19);
    std::cout.setf(std::ios_base::scientific);
    std::cout << d << std::endl;
    std::cout << ld << std::endl;
    return 0;
}

给出输出:

1.0000000000000000555e-01
1.0000000000000000555e-01

如果我们将cout.precision设置为 16,则输出将为:

1.0000000000000001e-01
1.0000000000000001e-01

没关系,第一个输出中 double 的第 17 位数字和第二个输出中第 16 位double位数字是不正确的。但是为什么对long double不正确?有没有办法获得long double变量的所有 19 个正确数字?

如果我尝试printf("%.19Len",ld);长双倍,我会得到完全相同的结果。

我使用 OpenSUSE 12.1 和 g++ 4.6.2。

0.1文字常量不是长双精度,它很可能是双精度数。

您可能希望使用 初始化ld

 long double ld = (long double) 1.0 / (long double) 10.0;

因此,除法涉及两个长双操作数,因此希望在长双精度中完成(我不确定,您必须仔细检查适当的C++标准)。

您可能希望使用支持最新标准的 GCC 进行编译。对于 GCC 4.7,我建议使用 g++ -Wall -std=c++11 进行编译,但对于您的 4.6,您可能需要说-std=c++0x