深度复制和动态强制转换unique_ptr

时间:2016-10-06 21:20:30

标签: c++ c++11 polymorphism unique-ptr deep-copy

假设我有类似以下的类:

class A { virtual ~A(); ... }
class B : public A { ... }
class C : public A { ... }

我还有一个unique_ptr的向量,它以这种方式声明:

std::vector<std::unique_ptr<A>> vec;

假设vec使用unique_ptr填充到派生类的对象。如果我想要任何向量元素(b或c)的深层副本,并让基类unique_ptr指向它,我该怎么办?最初我做的事情是

std::unique_ptr<A> tmp = std::make_unique<A>(*b);

我不认为这是正确的。有人可以帮我这个吗?

1 个答案:

答案 0 :(得分:3)

一种可能的解决方案是在基类中声明一个虚拟克隆方法,并为每个子类重写它:

class A {
    virtual ~A() {}
    virtual std::unique_ptr<A> clone() const = 0;
}
class B : public A {
    std::unique_ptr<A> clone() const override {
        return std::unique_ptr<A>(new B(*this));
    }
};

修改

一个用法示例:

void f(const A& original) {
    std::unique_ptr<A> copy = original.clone();
    // Here, copy points to an instance of class B.
}