C++ template可变参数的一次尝试

每个项目都会有自己的日志类,刚开始的时候就长这样:

FLog("blablablabla....")

如果要带其他参数的时候就会成这样:

FLog("index=" + QString::number(index) + "; val=" + val);

Oh, 我的天啊!好难用哦,即使是这样:

FLog(QString("index=%1; val=%2").arg(index).arg(val));

写多了也不好受啊!!! so… 可以用不定参数改一下上面的式子。我想是如果像 printf一样就好了。动起手来。。

template
void FLog(const QString &format, const Arg1& arg1, const Args& ...args)
{ FLog(format.arg(arg1), std::forward(args)...); }

代码就三行,对可变参数一点都不懂,在网上年了很久,慢慢试出来的。这样的话就可以这样写了:

FLog("index=%1; val=%2", index, val);

总之比第一种好看一点, 最终调用也是第一种哦, 可变参数模版使用的是递归,最终还是要个特例化的函数。

你可能感兴趣的:(项目总结)