每个项目都会有自己的日志类,刚开始的时候就长这样:
FLog("blablablabla....")
如果要带其他参数的时候就会成这样:
FLog("index=" + QString::number(index) + "; val=" + val);
Oh, 我的天啊!好难用哦,即使是这样:
FLog(QString("index=%1; val=%2").arg(index).arg(val));
写多了也不好受啊!!! so… 可以用不定参数改一下上面的式子。我想是如果像 printf一样就好了。动起手来。。
template<typename Arg1, typename ...Args>
void FLog(const QString &format, const Arg1& arg1, const Args& ...args)
{ FLog(format.arg(arg1), std::forward<const Args&>(args)...); }
代码就三行,对可变参数一点都不懂,在网上年了很久,慢慢试出来的。这样的话就可以这样写了:
FLog("index=%1; val=%2", index, val);
总之比第一种好看一点, 最终调用也是第一种哦, 可变参数模版使用的是递归,最终还是要个特例化的函数。