深度复制和动态转换 unique_ptr
deep copy and dynamic cast unique_ptr
假设我有一个 class 如下所示:
class A { virtual ~A(); ... }
class B : public A { ... }
class C : public A { ... }
我还有一个 unique_ptr 的向量,它是这样声明的:
std::vector<std::unique_ptr<A>> vec;
假设 vec 由 unique_ptr 填充到派生 class 的对象。如果我想要一个向量元素的任何一个深拷贝,无论是b还是c,让一个baseclassunique_ptr指向它,我该怎么办?本来我在做
这样的事情
std::unique_ptr<A> tmp = std::make_unique<A>(*b);
我认为这是不正确的。
一个可能的解决方案是在基class中声明一个虚拟克隆方法并为每个子class覆盖它:
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.
}
假设我有一个 class 如下所示:
class A { virtual ~A(); ... }
class B : public A { ... }
class C : public A { ... }
我还有一个 unique_ptr 的向量,它是这样声明的:
std::vector<std::unique_ptr<A>> vec;
假设 vec 由 unique_ptr 填充到派生 class 的对象。如果我想要一个向量元素的任何一个深拷贝,无论是b还是c,让一个baseclassunique_ptr指向它,我该怎么办?本来我在做
这样的事情std::unique_ptr<A> tmp = std::make_unique<A>(*b);
我认为这是不正确的。
一个可能的解决方案是在基class中声明一个虚拟克隆方法并为每个子class覆盖它:
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.
}