如何使包装类将其构造函数参数转发给 std::vector 的构造函数?

Cod*_*cks 2 c++ forwarding vector function-templates variadic-templates

我有一个wrapper类来包装std::vector<int>数据成员。我希望wrapper的构造函数将其参数转发给 的构造函数vector<int>。我尝试使用可变参数模板构造函数来实现这一点。由于std::vector<int> v{1, 2, 3}是由其std::initializer_listctor构建的,因此我希望在wrapper执行此操作时激活vectorinitializer_listctor

wrapper mywrap{1, 2, 3}.

但我没有得到想要的结果:

#include <iostream>
#include <vector>

struct wrapper {
    std::vector<int> v;
    template <typename ...Tn> wrapper(Tn ...args) : v(args...) {}
};

int main() {
                                                            //----Output----
    wrapper wrap1{ 1 };
    std::cout << wrap1.v.size() << std::endl;               // 1
    std::cout << wrap1.v.at(0) << std::endl;                // 0
    wrapper wrap2{ 1, 2 };
    std::cout << wrap2.v.size() << std::endl;               // 1
    std::cout << wrap2.v.at(0) << std::endl;                // 2
    wrapper wrap3{ 1, 2, 3 };                               // error
    wrapper wrap4{ std::initializer_list<int>{ 1, 2, 3 } }; // OK
}
Run Code Online (Sandbox Code Playgroud)

输出显示:

wrapper wrap1{ 1 };调用explicit vector (size_type n);

wrapper wrap2{ 1, 2 }; 电话

vector (size_type n, const value_type& val, const allocator_type& alloc = allocator_type());.

wrapper wrap3initializer_list<int>未指定时失败。

在所有情况下,我都希望vector's initializer_list<int>ctor 被激活。如何解决这个问题?

For*_*veR 5

初始化由()和初始化由之间的区别{},在您的构造函数中,您还应该使用{}初始化。

template <typename ...Tn> wrapper(Tn ...args) : v{args...} {}
Run Code Online (Sandbox Code Playgroud)

顺便说一句,如果你只想要initializer_listc-tor,为什么不简单地写这个c-tor呢?

wrapper(std::initializer_list<int> args) : v(args) {}
Run Code Online (Sandbox Code Playgroud)