0

我正在为用 C 实现的变体类型开发 C++11 包装器。变体类型支持常见的数据类型,如 int、float、string 以及tuples。我有表格基本类型的转换器......

template<typename T>
T convert_to(const Variant &var);

...但我正在努力转换为 std::tuple。

底层 C API 可以通过返回一个 Variants 数组来分解一个元组。它看起来像这样:

int get_tuple(Variant var, Variant **argv, int *argc);

现在我认识到我可以为每个大小的元组手动创建模板,但我正在寻找一个可以处理任何大小的元组的可变参数解决方案。关于如何解决这个问题的任何提示?

顺便说一句,我要包装的实际是 Erlang NIF API。

4

1 回答 1

2

由于您使用的是 C++11(并且您从模板参数中知道元组类型),因此您可以愉快地使用可变参数模板。就像是*

template <class ... Ts>
std::tuple<Ts...> convert_to(const Variant& v)
{
  Variant tmp_array[std::tuple_size<std::tuple<Ts...>>::value];
  get_tuple(v, tmp_array, sizeof(tmp_array)/sizeof(tmp_array[0]));
  std::tuple<Ts...> ret;
  array_to_tuple(ret, tmp_array);
  return ret;
}

wherearray_to_tuple将一一复制元素:

template <class ... Ts>
struct array_to_tupler
{
  template <int I>
  static void do_it(std::tuple<Ts...> &t, Variant* vs)
  {
    std::get<I-1>(t) = convert_to<decltype(std::get<I-1>(t))>(vs[I-1]);
    do_it<I-1>(t, vs);
  }
  template <>
  static void do_it<0>(std::tuple<Ts...> &t, Variant* vs)
  {
  }
};

template <int N, class ... Ts>
void array_to_tuple(std::tuple<Ts...> &t, Variant (&vs)[N])
{
  array_to_tupler<Ts...>::do_it<N>(t, vs);
}

希望这可以工作...

*) 请注意,这样convert_to将不容易调用。我建议使用类模板对返回类型进行专业化,因为您需要部分专业化,而函数模板不能。

于 2012-02-29T19:05:25.120 回答