如何访问variadic模板函数中的参数

How to access params in variadic template function

本文关键字:函数 参数 variadic 何访问 访问      更新时间:2023-10-16

在c/c 中使variadic函数的旧方法使用va_list,va_start,va_arg,va_end,va_end,va_end在cstdarg中定义。C 11带有variadic函数模板语法,但是如何访问值?

//example
#include <iostream>
using namespace std;
template <typename... types>
void print(types... Params){
  //this is not working:
  long Param1 = Params[0];
  long Param2 = Params[1];
}
int main(){
  print(123, 456);
  print(123, "foobar");
}

这是一种非常简单的(不破坏性(的方法,尽管也许不是最佳的:

#include <iostream>
#include<tuple>
#include<cassert>
using namespace std;
template <typename... types>
void print(types... Params){
  long Param1 = std::get<0>(std::tie(Params...));
  long Param2 = std::get<1>(std::tie(Params...));
  assert(Param1 == 123 and Param2 == 456);
}
int main(){
  print(123, 456);
}

https://godbolt.org/z/v8va0w

如果所有元素都是相同类型的(并且假设您可以复制它们(:

#include <iostream>
#include<tuple>
#include<cassert>
using namespace std;
template <typename... types>
void print(types... Params){
  std::array<long, sizeof...(Params)> params = {Params...};
  long Size = params.size();
  long Param1 = params[0];
  long Param2 = params[1];
  assert(Size == 2 and Param1 == 123 and Param2 == 456);
}
int main(){
  print(123, 456);
}

从您的问题中不清楚,但看起来您想打印列表中的所有元素,如果您只想这样做,那么您可以按照以下方式进行操作(需要C 17,但是您可以做这在C 11中进行了一些工作(:

#include <iostream>
using namespace std;
template <typename... types>
void print(types... Params){
    std::cout << "number of elements: " << sizeof...(Params) << " ";
    ((std::cout << Params), ...);
}
int main(){
  print(123, 456);
}

使用操作员&lt;&lt;这里:https://stackoverflow.com/a/5495309/5581893

但实际上不是一个函数调用,它是一系列呼叫运算符&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt;&lt》中必须是类型的方法。