C++中格式化浮点数常用iostream和iomanip,通过setprecision控制有效位或小数位,fixed固定小数格式,setw与setfill补零,scientific启用科学计数法。

在C++中格式化输出浮点数,常用的方法是通过iostream和iomanip头文件中的工具来控制精度、小数位数、补零、科学计数法等。下面介绍几种常用的格式化方式。
1. 控制小数位数:setprecision
使用std::setprecision可以设置浮点数输出的有效数字或小数位数,具体行为取决于是否启用了fixed。
默认情况下,setprecision(n)表示总共显示n个有效数字。
- 加上std::fixed后,setprecision(n)表示保留n位小数。
示例:
立即学习“C++免费学习笔记(深入)”;
#include#include int main() { double num = 3.1415926; std::cout << std::setprecision(5) << num << std::endl; // 输出:3.1416(共5位有效数字) std::cout << std::fixed << std::setprecision(2) << num << std::endl; // 输出:3.14(保留2位小数) return 0; }
2. 固定小数点格式:fixed
使用std::fixed可以让浮点数以固定小数位格式输出,而不是自动切换为科学计数法。
- 适用于需要统一小数位数的场景,比如金额、测量值等。
示例:
立即学习“C++免费学习笔记(深入)”;
std::cout << std::fixed << std::setprecision(3); std::cout << 12.1 << std::endl; // 输出:12.100 std::cout << 0.00123 << std::endl; // 输出:0.001
3. 补零输出:setw 和 setfill
如果希望在输出时补前导零(如时间、编号),可结合std::setw和std::setfill。
- setw(n) 设置最小字段宽度。
- setfill(c) 设置填充字符,默认为空格。
注意:setw只对下一次输出有效。
示例:
立即学习“C++免费学习笔记(深入)”;
#includedouble value = 3.14; std::cout << std::setfill('0') << std::setw(8) << std::fixed << std::setprecision(2) << value << std::endl; // 输出:00003.14(总宽8位,前面补0)
4. 强制使用科学计数法:scientific
使用std::scientific强制以科学计数法输出浮点数。
示例:
立即学习“C++免费学习笔记(深入)”;
std::cout << std::scientific << std::setprecision(3); std::cout << 1234.567 << std::endl; // 输出:1.235e+03
基本上就这些常用方法。结合fixed、setprecision、setw等,可以灵活控制浮点数的显示格式,满足不同场景需求。不复杂但容易忽略细节,比如fixed的影响范围或setw的单次有效性。











