如何在C ++ 17中创建从可变参数模板推导的向量类型的元组?

时间:2018-11-14 17:06:17

标签: c++ c++17 variadic-templates stdtuple structure-of-arrays

我实现了一个收集类,该收集类将元组的向量转换为向量的元组(它实质上是AOS到SOA的转换)。此代码适用于两个模板类的示例。我试图通过使用可变参数模板使其更通用。为此,我需要为成员变量m_col创建类型。在C ++ 17中,是否可以将元组转换为向量的元组?因此,此示例中的成员差异m_col的类型将根据模板类型自动生成。

template<class T1, class T2>
class Collection
{
    std::tuple<std::vector<T1>, std::vector<T2>> m_col;

public:
    void addRow(const std::tuple<T1, T2>& data)
    {
        std::get<0>(m_col).push_back(std::get<0>(data));
        std::get<1>(m_col).push_back(std::get<1>(data));
    } 

    void show()
    {
        std::cout << std::get<0>(m_col1).size() <<std::endl;
    }
};


int main()
{
    using data_t = std::tuple<int, double>;
    data_t data{1,1.0};
    using col_t = Collection<int, double>;
    col_t col;
    col.addRow(data);    
    col.show();
}

2 个答案:

答案 0 :(得分:4)

您可以使用std::index_sequence

template<class ... Ts>
class Collection
{
    std::tuple<std::vector<Ts>...> m_col;

private:

    template <std::size_t ... Is>
    void addRow(std::index_sequence<Is...>, const std::tuple<Ts...>& data)
    {
        (std::get<Is>(m_col).push_back(std::get<Is>(data)), ...);
    } 

public:
    void addRow(const std::tuple<Ts...>& data)
    {
        addRow(std::index_sequence_for<Ts...>(), data);
    } 

};

Demo

答案 1 :(得分:3)

您正在使用C ++ 17,所以...使用模板折叠和一些std::apply()怎么办?

我的意思是

template <typename ... Ts>
class Collection
 {
   private:
      std::tuple<std::vector<Ts>...> m_col;

   public:
      void addRow (std::tuple<Ts...> const & data)
       {
          std::apply([&](auto & ... vectors){
                     std::apply([&](auto & ... values){
                                (vectors.push_back(values), ...);},
                                data); },
                     m_col);        
       } 

      void show () const
       {
         std::apply([](auto & ... vectors){
             ((std::cout << vectors.size() << '\n'), ...);}, m_col);
       }
 };