std::setprecision

来自cppreference.com
< cpp‎ | io‎ | manip
定义于头文件 <iomanip>
/*unspecified*/ setprecision( int n );

用于表达式 out << setprecision(n)in >> setprecision(n) 时,设置流 outinprecision 参数准确为 n

目录

[编辑] 参数

n - 精度的新值

[编辑] 返回值

返回未指定类型的对象,使得若 strstd::basic_ostream<CharT, Traits> 类型的输出流名称或 std::basic_istream<CharT, Traits> 类型的输入流名称,则表达式 str << setprecision(n)str >> setprecision(n) 表现为如同执行下列代码:

str.precision(n);

[编辑] 示例

#include <iostream>
#include <iomanip>
#include <cmath>
#include <limits>
int main()
{
    const long double pi = std::acos(-1.L);
    std::cout << "default precision (6): " << pi << '\n'
              << "std::setprecision(10): " << std::setprecision(10) << pi << '\n'
              << "max precision:         "
              << std::setprecision(std::numeric_limits<long double>::digits10 + 1)
              << pi << '\n';
}

输出:

default precision (6): 3.14159
std::setprecision(10): 3.141592654
max precision:         3.141592653589793239

[编辑] 参阅

更改用于浮点 I/O 的格式化
(函数) [编辑]
管理浮点操作的精度
(std::ios_base 的公开成员函数) [编辑]