用于将 unique_ptr 的向量初始化为基本类型的可变参数构造函数

Variadic construction for initialising vector of unique_ptr to base type

下面是一个示例程序,其中 'Container' class 需要通过基 class 指针存储 'Items' 的列表。从 C++11/14 开始,在我的情况下,自然的选择是使用 std::unique_ptr 和可变参数模板。

但是作为新手,我无法理解如何以编译的方式将可变参数列表转换为 unique_ptr 向量的初始化列表。非常感谢帮助,因为到目前为止我未能在网上找到任何可以帮助我解决这个问题的东西(尽管可能在那里!)。

提前致谢:

// Example program
#include <iostream>
#include <string>
#include <memory>
#include <vector>

struct Item
{
};


struct Container
{
    template<typename... Items>
    Container( Items&&... items ) 
    : items_( {std::make_unique<Items>(items)...} ) //<<TODO: How, VC compiler times out with this code!?
    {
    }

    std::vector<std::unique_ptr<Item>> items_;
};

struct A : Item { A(float){}  };
struct B : Item {  };
struct C : B    { C(float){} };
struct D : Item { D(float){} };

int main()
{
  Container x( A(1), C(2), D(3) );

  return 0;
}

问题是您无法将 unique_ptrintializer_list 移出。阅读 this question 了解更多详情。

此解决方案使用 this answer 中的技术,而不是使用 intializer_list,您可以使用普通数组来构造项。

struct Container
{
    template<typename... Items>
    Container( Items&&... items ) 
    : items_()
    {
        std::unique_ptr<Item> itemArr[] = {std::make_unique<Items>(std::move(items))...};
        items_ = std::vector<std::unique_ptr<Item>> {std::make_move_iterator(std::begin(itemArr)), std::make_move_iterator(std::end(itemArr))};
    }

    std::vector<std::unique_ptr<Item>> items_;
};

Online Demo