1

如果我想编写一个通用的复制构造函数(一个可以接受任何参数类型的构造函数),这很容易做到:

class Widget {
public:
  template<typename T> Widget(T&& other);
};

这不会阻止编译器生成传统的复制构造函数,所以我想自己编写并委托给模板。但是我该怎么做呢?

class Widget {
public:
  template<typename T> Widget(T&& other);
  Widget(const Widget& other): ??? {}         // how delegate to the template?
};

我试图用这种方式编写委托构造函数,

Widget(const Widget& other): Widget<const Widget&>(other){}

但是 VC11、gcc 4.8 和 clang 3.2 都拒绝它。

如何编写我正在尝试编写的委托复制构造函数?

4

1 回答 1

3

您不能为构造函数模板指定模板参数;你仅限于扣除。也许您可以从我的一篇旧帖子中调整答案

// NOT Tested!
#include <utility>

class Widget
{
    enum fwd_t { fwd };

    // Your true master constructor
    template< typename T >  Widget( fwd_t, T &&t );

public:
    template < typename T >
    Widget( T&& other );
        : Widget( fwd, std::forward<T>(other) )
    {}
    Widget( const Widget& other )
        : Widget( fwd, other )
    {}
};

两个单参数构造函数转发到一个双参数兄弟构造函数。

于 2013-04-29T06:33:30.140 回答