以下代码将std::string
转换为boost::posix_time::ptime
。
分析后,我发现在该函数上花费的大部分时间(约90%)浪费在time_input_facet
的内存分配上。我不得不承认我不完全理解以下代码,尤其是为什么必须在空闲内存上分配time_input_facet
。
using boost::posix_time;
const ptime StringToPtime(const string &zeitstempel, const string &formatstring)
{
stringstream ss;
time_input_facet* input_facet = new time_input_facet();
ss.imbue(locale(ss.getloc(), input_facet));
input_facet->format(formatstring.c_str());
ss.str(zeitstempel);
ptime timestamp;
ss >> timestamp;
return timestamp;
}
您是否看到任何摆脱分配的方法?
最佳答案
在函数内部使input_facet静态:
static time_input_facet *input_facet = new time_input_facet();
这将仅在第一个函数调用上构造构面,并将重用构面。我相信,该构面允许在同一对象上进行多个后续调用。
更新:您也不需要同时构造字符串流和语言环境。只需在单独的函数中或在静态初始化中执行一次,然后使用流。
更新2:
const ptime StringToPtime(const string &zeitstempel, const string &formatstring)
{
static stringstream ss;
static time_input_facet *input_facet = NULL;
if (!input_facet)
{
input_facet = new time_input_facet(1);
ss.imbue(locale(locale(), input_facet));
}
input_facet->format(formatstring.c_str());
ss.str(zeitstempel);
ptime timestamp;
ss >> timestamp;
ss.clear();
return timestamp;
}