N维向量的递归可变参数模板函数

约翰特拉沃尔斯基

一段时间以来,我一直在努力解决这个问题,但我似乎无法做到。

我想做的是创建一个模板函数,它需要任意数量的 char 参数参数,然后是一个 std::string 作为参数。示例语法如下所示:

nvec<3, std::string> info = string_to_vec<':', ';', '-'>(data);

nvec 是一个递归模板类,它创建一个基于特定类型模板的 n 维向量。它的代码相当简单,可以在这里看到:

template <size_t dim, typename T>
struct multidimensional_vector
{
  typedef std::vector<typename multidimensional_vector<dim - 1, T>::type> type;
};

template <typename T>
struct multidimensional_vector<0, T>
{
  typedef T type;
};

template <size_t dim, typename T>
using nvec = typename multidimensional_vector<dim, typename T>::type;

但是,string_to_vec 可能需要任意数量的字符参数(但至少有一个)。然后,它需要对这些信息做的是返回一个相应的 n 维字符串向量,其中插入的数据由这些字符分隔。例如,假设我传入的 std::string 如下所示:

std::string data = "1:2:3;4:5:6;7:8:9-10:11:12;13:14:15;16:17:18"

然后我希望这个函数返回一个 n 维向量(在类型字符串上模板化),它可以像这样访问:

info[0][0][0] // = 1
info[1][0][0] // = 10
info[1][1][1] // = 14
info[1][2][2] // = 18
// etc.

尽管如果提前知道向量的大小(只需使用大量 for 循环),这并不难做到,但是当数据包含任意数量的分隔符(意味着向量可以是任何尺寸)。这可能与递归可变参数模板有关吗?如果是这样,老实说,我不知道从哪里开始。

伊戈尔垃圾桶

如果分隔符从上到下列出,首先列出更高级别,则更容易。如果那没问题,那么沿着这些方向:

template <char... delims>
struct StringToVecHelper {
    static std::string convert(const std::string& data) { return data; }
};

template <char delim, char... tail>
struct StringToVecHelper<delim, tail...> {

static nvec<sizeof...(tail)+1, std::string> convert(const std::string& data) {
    nvec<sizeof...(tail)+1, std::string> result;
    size_t start = 0;
    for (;;) {
        size_t pos = data.find(delim, start);
        std::string piece(data, start, pos - start);
        result.push_back(StringToVecHelper<tail...>::convert(piece));
        if (pos == std::string::npos) break;
        start = pos + 1;
    }
    return result;
}
};

template <char... delims>
auto string_to_vec(const std::string& data) {
    return StringToVecHelper<delims...>::convert(data);
}

演示

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章