我Vector
用 C++ 创建了一个类,它对我的问题很有用。我现在正在清理它,我遇到了以下代码:
std::ostream& operator<<(std::ostream &output, const Vector &v){
output<<"["
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._x<<", "
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._y<<", "
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._z<<"]";
return output;
}
该代码允许将向量打印为std::cout<<v<<std::endl;
. 每个数字有 23 个空格,其中 16 个是小数。文本右对齐,以便打印:
1.123456123456e+01
-1.123456123456e+01
代替
1.123456123456e+01
-1.123456123456e+01
代码似乎非常重复。您如何“存储”格式(所有setiosflags
,setw
和setprecision
语句),以便您可以说“以标准方式打印字符,但以这种给定格式打印数字”。
谢谢!
编辑
根据 Rob Adams 的评论,我将丑陋的代码(正如其他人所指出的那样,会弄乱“下一个人”的精确度)更简洁(并且正确):
std::ostream& operator<<(std::ostream &output, const Vector &v){
std::ios_base::fmtflags f = output.flags(std::ios::right | std::ios::scientific);
std::streamsize p = output.precision(16);
output<<"["
<<std::setw(23)<<v._x<<", "
<<std::setw(23)<<v._y<<", "
<<std::setw(23)<<v._z
<<"]";
output.flags(f);
output.precision(p);
return output;
}