为了提高性能,我希望更换:
template<class T> std::string ToStringFixed(const T x, const unsigned int width = 8)
{
std::stringstream ss;
ss << std::setprecision(width) << std::fixed << x;
return ss.str();
}
由于Boost Karma的实施已经使用了Boost,它看起来比上面的天真解决方案有显着的性能提升。
类似的东西:
std::string ToString(double d)
{
using boost::spirit::karma::double_;
using boost::spirit::ascii::space;
using boost::spirit::karma::generate;
std::string s
std::back_insert_iterator<std::string> sink(s);
generate(sink, double_, d);
return s;
}
采用的是:http://thisthread.blogspot.com/2011/04/generating-text-with-spirit-karma.html似乎是在正确的轨道上,但我不清楚如何控制精度,或者这样的解决方案是否适用于浮点模板不使用类型特征的类型。 (通过C ++ 14使用的答案是可以接受的。)
答案 0 :(得分:5)
您可以在real_generator
's formatting policies的帮助下实现您想要的效果。由于您只需要修改可以从默认real_policies<Num>
派生的精度,然后添加具有您所需行为的precision(Num n)
成员函数。
#include <iostream>
#include <string>
#include <cmath>
#include <boost/spirit/include/karma.hpp>
template <typename Num>
struct precision_policy : boost::spirit::karma::real_policies<Num>
{
precision_policy(int prec):precision_(prec){}
int precision(Num n) const { return precision_; }
int precision_;
};
std::string ToStringFixedKarma(double d, const unsigned int width = 8)
{
using boost::spirit::karma::real_generator;
using boost::spirit::ascii::space;
using boost::spirit::karma::generate;
real_generator<double,precision_policy<double> > my_double_(width);
std::string s;
std::back_insert_iterator<std::string> sink(s);
generate(sink, my_double_, d);
return s;
}
int main() {
const double pi = std::acos(-1);
std::cout << ToStringFixedKarma(pi) << std::endl;
std::cout << ToStringFixedKarma(pi,2) << std::endl;
std::cout << ToStringFixedKarma(pi,4) << std::endl;
}
PS:文档(并检查源代码)似乎暗示这些策略中的成员函数需要是静态的,这将使您所需要的东西变得不可能,但正如this example所示,情况并非如此