C++ 中的 cout 浮点格式

cout floating point format in c++

本文关键字:格式 cout 中的 C++      更新时间:2023-10-16
std::ostream& operator<<(std::ostream& o, const mat4& m)
{
    o << std::setprecision(6) << std::fixed << std::right;
    const int w = 8;
    for (int i = 0; i < 4; i++)
    {
        int j = 4 * i;
        o << '[' << std::setw(w) << m[j] << ',' << std::setw(w) << m[1 + j] << ',' << std::setw(w)  <<  m[2 + j] << ',' << std::setw(w) << m[3 + j] << ']' << std::endl;
    }
    return o;
}

我想将数据打印为:

[-1.00000, 1.00000, 123.000,-23.0000]

这就是我想要实现的目标:

  • 如果负号不存在,则添加空格
  • 字符串的大小是固定的,它只显示最重要的值

我正在考虑使用 std::fixedstd::scientific但无法弄清楚如何使用 iomanip 实现上述格式。这甚至可以用iomanip完成吗,还是我需要实现自己的方法?

你想要setiosflags(ios_base::showpoint)

#include <iomanip>
#include <iostream>
int main()
{
  double m[] = {-1, 1, 123, -23};
  const int w = 8;
  std::cout << std::setiosflags(std::ios_base::showpoint);
  std::cout << '[' << std::setw(w) << m[0] << ',' << std::setw(w) << m[1] << ',' << std::setw(w)  <<  m[2] << ',' << std::setw(w) << m[3] << ']' << std::endl;
}

结果是:

[-1.00000, 1.00000, 123.000,-23.0000]