我在C++中创建了一个Vector
类,它对我的问题非常有效。现在我正在对其进行清理,然后遇到了以下代码:
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;
}