必须搭配 std::fixed 和 std::setprecision(2) 才能稳定输出两位小数,因为单独 setprecision(2) 控制总有效数字位数(如 123.456 变为 1.2e+02),而 std::fixed 使 setprecision 意义变为小数点后位数,且其状态持久需手动取消。
直接用 std::fixed + std::setprecision(2),否则 setprecision 控制的是有效数字位数,不是小数位数。
setprecision(2) 单独用不行?因为 std::setprecision 默认作用于「总有效数字位数」,不是小数点后几位。比如 123.456 用 setprecisi 会输出 
1.2e+02(即 120),而不是 123.46 或 123.45。
必须搭配 std::fixed(固定小数点格式)才能让 setprecision 意义变为「小数点后保留几位」。
std::fixed 让浮点数按十进制小数形式输出,禁用科学计数法std::setprecision(2) 在 fixed 下才表示「小数点后两位」fixed)最简可靠写法:
#include#include int main() { double x = 3.14159; std::cout << std::fixed << std::setprecision(2) << x << '\n'; // 输出: 3.14 }
注意:
std::showpoint —— fixed 已保证小数点和两位小数始终显示(如 5.00)std::cout.unsetf(std::ios_base::floatfield);
std::defaultfloat 回退 —— 它在旧标准(C++98/03)不支持,兼容性差这些写法容易出错:
std::setprecision(2) 单独用 → 输出可能是 3.1(有效数字 2 位),不是 3.14
std::fixed 但忘了 std::setprecision → 小数位数由流默认精度决定(通常是 6),输出 3.141590
std::fixed 和 std::setprecision → 不必要,设一次即可,除非中间混用了其他格式printf("%.2f", x) 混合 C 风格 → 虽然能用,但和 iostream 状态不互通,std::cin 后混用可能有缓冲或 locale 冲突真正要注意的其实是状态持久性:一旦设置了 std::fixed,它会一直生效直到显式取消。很多 bug 都是前一段代码设了 fixed,后面另一段数值处理逻辑意外被格式化成两位小数,还查不出原因。