为什么在使用setprecision修复时使用showpoint?

时间:2015-02-16 23:14:26

标签: c++ iostream iomanip

我不太明白showpoint的目的,我知道它强制显示一个小数点,但是如果没有使用showpoint,那么“cout<< setprecision<< fixed”就足够了。

你能告诉我一个必须有showpoint的例子吗?

2 个答案:

答案 0 :(得分:3)

当覆盖大范围的值时,可能需要使格式化逻辑在使用固定点和科学记数法之间切换,同时仍需要小数点。如果你查看这个例子的输出,你会发现它不仅仅是定点符号:

#include <iostream>

int main() {
    for (double value(1e15), divisor(1); divisor < 1e20; divisor *= 10) {
        std::cout << std::noshowpoint << (value / divisor) << '\t'
                  << std::showpoint << (value / divisor)
                  << '\n';
    }
}

这会产生输出

1e+15   1.00000e+15
1e+14   1.00000e+14
1e+13   1.00000e+13
1e+12   1.00000e+12
1e+11   1.00000e+11
1e+10   1.00000e+10
1e+09   1.00000e+09
1e+08   1.00000e+08
1e+07   1.00000e+07
1e+06   1.00000e+06
100000  100000.
10000   10000.0
1000    1000.00
100 100.000
10  10.0000
1   1.00000
0.1 0.100000
0.01    0.0100000
0.001   0.00100000
0.0001  0.000100000

答案 1 :(得分:2)

如果精度为0且未使用showpoint,则不会显示小数点,否则会出现:

#include <iostream>
#include <iomanip>

int
main()
{
    double pi = 2646693125139304345./842468587426513207.;
    std::cout << std::fixed << std::setprecision(0);
    std::cout << pi << '\n';
    std::cout << std::showpoint;
    std::cout << pi << '\n';
}

应输出:

3
3.