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

来源:互联网 发布:录制视频软件下载 编辑:程序博客网 时间:2024/06/05 21:08

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

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);

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

0 0
原创粉丝点击