如何在C++11中将参数的数组初始值设定项迁移到可变模板参数

How to migrate array-initializer of arguments to variardic template arguments in C++11

本文关键字:参数 迁移 C++11 数组      更新时间:2023-10-16

我有一些代码是在我们的平台上有c++11编译器之前编写的。最后,我们可以开始使用c++11特性,因为最后一个平台终于赶上了。因此,我试图用可变模板清理一些长的"通过复制粘贴具有N个参数的函数"链。然而,我承认,我不太知道如何解决以下案件。我有一个Format()方法,它将参数打包到变量中,然后将它们传递到隐藏在源文件中的函数中(以减少膨胀、包括依赖项等)。如何将模板参数解包到数组中以传递到方法中?

struct Variant
{
    enum ValueType { Integer, Float };
    Variant(int _value) { value._asInt = _value; valueType = Integer}
    // ... and other constructors
    union Value
    {
        int _asInt;
        // ... other types including specific user types
    } value;
    ValueType valueType;
};
// Implementation burried in source file
extern size_t FormatStringImpl(const char* format, char * dest, size_t capacity, Variant variants[], size_t numVariants);
template<class T0>
size_t Format(const char* format, char* dest, size_t capacity, T0 var0)
{
    Variant variants[] = { Variant(var0) };
    return FormatStringImpl(format, dest, capacity, variants, sizeof(variants) / sizeof(variants[0]));
}
template<class T0, class T1>
size_t Format(const char* format, char* dest, size_t capacity, T0 var0, T1 var1)
{
    Variant variants[] = { Variant(var0), Variant(var1) };
    return FormatStringImpl(format, dest, capacity, variants, sizeof(variants) / sizeof(variants[0]));
}
// and on and on
void foo()
{
    const size_t length = 1024;
    char output[length];
    Format("Values are {0}, {1}, {2}", output, length, 10, 20, 30);
}

细节有些复杂,但其要点是捕获类型/数据并将其拉入源文件进行处理的一种方法。我想在堆栈上执行所有分配,所以在这里的解包循环中使用std::vector是行不通的。

Format可以简化为:

template<class ... Ts>
size_t Format(const char* format, char* dest, size_t capacity, Ts... vars)
{
    Variant variants[] = { Variant(vars)... };
    return FormatStringImpl(format, dest, capacity, variants, sizeof...(vars));
}

我还用sizeof...(vars) 替换了sizeof(variants) / sizeof(variants[0])