В качестве примера предположим, что вы хотите отображать каждый A :: var. Я вижу три способа сделать это, как показывает приведенный ниже код.
Что касается варианта 2, обратите внимание, что порядок, в котором элементы обрабатываются, не указан стандартом.
#include <iostream>
#include <initializer_list>
template <int i>
struct Int {
static const int var = i;
};
template <typename T>
void do_something(std::initializer_list<T> list) {
for (auto i : list)
std::cout << i << std::endl;
}
template <class... A>
void expand(A&&...) {
}
template <class... A>
void do_something() {
// 1st option:
do_something({ A::var... });
// 2nd option:
expand((std::cout << A::var << std::endl)...);
// 3rd option:
{
int x[] = { (std::cout << A::var << std::endl, 0)... };
(void) x;
}
}
int main() {
do_something<Int<1>, Int<2>, Int<3>>();
}
[Это Q & A] (http://stackoverflow.com/questions/14261183/how-to-make-generic-computations-over-heterogeneous-argument-packs-of-a-variadic) должно помочь. –
У меня нет аргументов в моей функции, ссылка имеет аргументы. – user1095108
Кого волнует, если есть аргументы? Речь идет о расширении вариаций, работает одинаково. –