c – 将可变参数模板参数传递给可变参数函数
作者:互联网
我们正在使用第三方C库,它提供了printf()风格的日志功能,
void log(const char *format, ...);
由于不值得进入的原因,我们需要限制消息记录的速率,这有点像
void rate_limited_log(const char* format, ...)
{
if (<not too fast>) {
log(format, ...);
}
}
幸运的是,C库的作者知道他们在做什么,并提供了
void logv(const char* format, va_list ap);
所以写上面的函数是一件相对简单的事情.不幸的是variadic functions don’t play well with inlining,所以我想出了第二个解决方案:
template <typename... T>
void rate_limited_log(const char* format, T&&... args)
{
if (<not too fast>) {
log(format, std::forward<T>(args)...);
}
}
这完美地工作,并按照我们的意愿内联速率限制条件.但我有几个问题:
>将参数包扩展为C风格的可变参数函数调用,这样在C 11中可以做一个合法的,明确定义的事情,或者让我们幸运的是它有效吗?
>和&&鉴于我们正在调用C函数,std :: forward实际上是必要的吗?如果我使用const T&或者甚至只是T值,有或没有std :: forward,它似乎也能正常工作.
解决方法:
将参数包扩展为varargs是有效的.
当你想转发时,转发没有坏处.但是以const& amp;还传达了有用的东西.
传递给…的值将经历“默认参数促销”.见http://en.cppreference.com/w/cpp/language/variadic_arguments
这些都不关心参考文献.
您可以改进代码.您可以通过“类型”和实际解析格式化字符串并确认参数的数量(有时是类型)来检查Ts …是否是传递给打印例程的有效类型.如果失败,您可以记录错误消息而不是崩溃.
标签:perfect-forwarding,c,c11,variadic-templates,variadic-functions 来源: https://codeday.me/bug/20191007/1868822.html