如何在可变参数包中扩展向量或数组?

时间:2016-04-05 10:35:37

标签: c++ variadic-templates

我想在可变参数模板包中展开数组或向量。 请考虑以下示例:

template <typename T>
int GetArgValue(std::string name,T& value){
   cout<<"GetArgumentValue(): name="<<name<<", val="<<value<<endl;
   //Set value
   //...                        
   return 0;
}

template<typename ... Tn>
int GetArgValues(std::vector<std::string> keys, Tn&... values){
  //Check sizes
  //...

  //Call GetArg over pack
  int retCodes[] = { GetArgValue(keys,values)...};//not possible

  //...
  return 0; 
}

是否可以将数组或向量与包一起扩展?如果不是这个用例的合适方法是什么? 我想在最后实现的目标如下:

double arg1;
int arg2;
std::string arg3;
GetArgValues({"firstArg","secondArg","thirdArg"},arg1,arg2,arg3);

甚至更好(如果可能):

GetArgValues( {"firstArg",arg1}, {"secondArg",arg2}, {"thirdArg", arg3} );

希望这个例子很清楚。 谢谢大家的建议。

1 个答案:

答案 0 :(得分:3)

您可以使用std::index_sequence。请注意,这是C ++ 14,但如果需要,C ++ 11还有很多实现。

我们创建一个辅助函数,它将接收编译时生成的索引序列,以访问向量:

template<typename ... Tn, std::size_t...  Idx>
int GetArgValuesHelp(std::index_sequence<Idx...>,
                     std::vector<std::string> keys,
                     Tn&... values){
  int retCodes[] = { GetArgValue(keys[Idx],values)...};

  return 0; 
}

然后调用该函数并从GetArgValues生成索引:

template<typename ... Tn>
int GetArgValues(std::vector<std::string> keys, Tn&... values){
  //Check sizes
  //...

  return GetArgValuesHelp(std::index_sequence_for<Tn...>{}, keys, values...);
}

Live Demo