如何获取参数包中元素的索引

How do I get index of elements in parameter pack

本文关键字:包中 元素 索引 参数 何获取 获取      更新时间:2023-10-16

如何获得以下内容以将参数包元素的索引放在元组中?

template< typename... Ts >
class ClassA {
public:
    ClassA( Ts... ts ) : tup( make_tuple( ts, 0 )... ) {}
    // I would like it to expand to this.
    // ClassA( T0 ts0, T1 ts1 ) : tup( make_tuple( ts0, 0 ), make_tuple(ts1, 1) ) {}
    tuple<tuple<Ts, size_t>...> tup;
};
void main() {
    vector<int> a ={ 2, 4, 5 };
    list<double> b ={ 1.1, 2.2, 3.3 };
    ClassA<vector<int>, list<double>, vector<int>, list<double>> mm( a, b, a, b );
}

谢谢。

在我看来

(如果您至少可以使用 C++14(委托构造函数的工作

template <typename ... Ts>
class ClassA
 {
   private:
      template <std::size_t ... Is>
      ClassA (std::index_sequence<Is...> const &, Ts ... ts)
         : tup { std::make_tuple(ts, Is) ... }
       { }
   public:
      ClassA (Ts ... ts)
         : ClassA(std::make_index_sequence<sizeof...(Ts)>{}, ts...)
       { }
      std::tuple<std::tuple<Ts, std::size_t>...> tup;
 };

在 C++11 中,这不起作用,因为std::index_sequencestd::make_index_sequence仅从 C++14 开始可用,但不难找到(或开发(C++11 替代品。

您可以通过简单地增加整数作为包扩展的一部分来避免使构造函数成为模板和索引序列:

template <typename ... Ts>
class ClassA
 {
   private:
      ClassA (size_t i, Ts ... ts)
         : tup { std::make_tuple(ts, i++) ... }
       { }
   public:
      ClassA (Ts ... ts)
         : ClassA(0, ts...)
       { }
      std::tuple<std::tuple<Ts, size_t>...> tup;
 };

应该注意 gcc 目前正在向我发出关于缺少序列点的警告,但这似乎是一个误报(无论如何,这可以通过编写一个小函数并调用它来轻松修复(。