std::setprecision
来自cppreference.com
| 在标头 <iomanip> 定义
|
||
| |
||
用于表达式 out << setprecision(n) 或 in >> setprecision(n) 时,设置流 out 或 in 的 precision 参数为 n。
参数
| n | - | 精度的新值 |
返回值
一个满足以下条件但未指定类型的对象:
- 如果
out是具有std::basic_ostream<CharT, Traits>类型的对象,那么表达式out << setprecision(n):- 具有
std::basic_ostream<CharT, Traits>&类型 - 值为
out - 行为如同调用
f(out, n)
- 具有
- 如果
in是具有std::basic_istream<CharT, Traits>类型的对象,那么表达式in >> setprecision(n):- 具有
std::basic_istream<CharT, Traits>&类型 - 值为
in - 行为如同调用
f(in, n)
- 具有
其中函数 f 定义如下:
void f(std::ios_base& str, int n)
{
// 设置精度
str.precision(n);
}
示例
运行此代码
#include <iomanip>
#include <iostream>
#include <limits>
#include <numbers>
int main()
{
constexpr long double pi{std::numbers::pi_v<long double>};
const auto default_precision{std::cout.precision()};
constexpr auto max_precision{std::numeric_limits<long double>::digits10 + 1};
std::cout << "默认精度:" << default_precision << '\n'
<< "最大精度:" << max_precision << "\n\n"
"精度: pi:\n";
for (int p{0}; p <= max_precision; ++p)
std::cout << std::setw(2) << p << " " << std::setprecision(p) << pi << '\n';
std::cout << std::setprecision(default_precision); // 恢复默认
}
输出:
默认精度:6
最大精度:19
精度: pi:
0 3
1 3
2 3.1
3 3.14
4 3.142
5 3.1416
6 3.14159
7 3.141593
8 3.1415927
9 3.14159265
10 3.141592654
11 3.1415926536
12 3.14159265359
13 3.14159265359
14 3.1415926535898
15 3.14159265358979
16 3.141592653589793
17 3.1415926535897932
18 3.14159265358979324
19 3.141592653589793239
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
|---|---|---|---|
| LWG 183 | C++98 | setprecision 只能用于具有 std::ostream 或 std::istream 类型的流
|
可以用于所有字符流 |
参阅
(C++11)(C++11) |
更改用数于浮点数 I/O 的格式化 (函数) |
| 管理浮点数操作的精度 ( std::ios_base 的公开成员函数)
|