std::setprecision

来自cppreference.com
< cpp‎ | io‎ | manip
 
 
 
输入/输出操纵符
浮点格式化
setprecision
整数格式化
布尔格式化
域宽与填充控制
其他格式化
空白符处理
输出冲入
状态标志操纵
时间与金钱 I/O
(C++11)
(C++11)
(C++11)
(C++11)
带引号操纵符
(C++14)
 
定义于头文件 <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 的公开成员函数)