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 …是否是传递给打印例程的有效类型.如果失败,您可以记录错误消息而不是崩溃.

转载注明原文:c – 将可变参数模板参数传递给可变参数函数 - 代码日志