Я создал класс 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
) таким образом, чтобы можно было сказать что-то вроде «напечатать символы в стандартном формате» способ, но числа в этом заданном формате ».
Спасибо!
Изменить
Согласно комментарию Роба Адамса, я изменил свой уродливый код (который, как указали другие, испортит точность для «следующего парня») в более сжатый (и правильный):
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;
}