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

deep copy and dynamic cast unique_ptr

本文关键字:转换 unique ptr 复制 动态 深度      更新时间:2023-10-16

假设我有一个这样的类:

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

也有一个unique_ptr类型的vector,声明如下:

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

假设vec用unique_ptr填充到派生类的对象。如果我想要任何向量元素的深度拷贝,无论是b还是c,并让基类unique_ptr指向它,我该怎么做?最初我做的是像

这样的东西
std::unique_ptr<A> tmp = std::make_unique<A>(*b);

我不认为这是正确的。

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

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.
}