setprecision用于控制浮点数输出精度,需包含iomanip头文件。默认下设置有效数字位数,配合fixed可指定小数点后位数,如cout

在C++中,setprecision 是一个用于控制浮点数输出精度的常用工具,常用于需要精确显示小数位数的场景,比如金融计算、科学计算或格式化输出。它定义在 iomanip 头文件中,必须包含该头文件才能使用。
setprecision 的基本用法
setprecision 是一个操作符(manipulator),用于设置浮点数的输出精度。它的作用取决于当前的浮点数输出格式(默认是有效数字位数)。
基本语法如下:
cout << setprecision(n) << value;
其中 n 表示要保留的有效数字位数或小数位数,具体行为由输出格式决定。
立即学习“C++免费学习笔记(深入)”;
配合 fixed 控制小数位数
如果不加任何格式控制,默认情况下 setprecision 设置的是总的有效数字位数,而不是小数点后的位数。例如:
#include#include using namespace std; int main() { double num = 3.1415926; cout << setprecision(3) << num << endl; // 输出:3.14(共3位有效数字) return 0; }
如果想让 setprecision 控制小数点后位数,必须配合 fixed 使用:
cout << fixed << setprecision(2) << num; // 输出:3.14
fixed 会将浮点数以定点格式输出,此时 setprecision 的参数表示小数点后的位数。
常见使用场景与技巧
-
保留两位小数(常用在金额输出):
cout << fixed << setprecision(2) << 123.456; // 输出:123.46(自动四舍五入)
-
恢复默认格式:使用 defaultfloat(C++11 起支持)可以取消 fixed 格式:
cout << defaultfloat;
-
结合其他格式控制:如 setw、left、right 等,实现对齐输出:
cout << fixed << setprecision(2) << setw(10) << left << num;
注意事项
- setprecision 的效果是持久的,一旦设置,后续所有浮点数输出都会受其影响,直到再次修改。
- 若不使用 fixed,setprecision 控制的是有效数字总数,可能造成误解。
- 输出时会自动进行四舍五入。
基本上就这些。掌握 setprecision 和 fixed 的配合使用,就能灵活控制 C++ 中浮点数的输出格式,满足大多数精度要求。不复杂但容易忽略细节。










