我正在创建一个具有多种不同节点类型的树:二进制节点,一元节点和终端节点。我有一个所有节点继承的ABC。我正在尝试为树编写递归复制构造函数,如下所示:
class gpnode
{
public:
gpnode() {};
virtual ~gpnode() {};
gpnode(const gpnode& src) {};
gpnode* parent;
}
class bnode:gpnode
{
public:
bnode() {//stuff};
~bnode() {//recursive delete};
bnode(const bnode& src)
{
lnode = gpnode(src.lnode);
rnode = gpnode(src.rnode);
lnode->parent = this;
rnode->parent = this;
}
gpnode* lnode;
gpnode* rnode;
}
class unode:gpnode
{
public:
unode() {//stuff};
~unode() {//recursive delete};
unode(const unode& src)
{
node = gpnode(src.node);
node->parent = this;
}
gpnode* node;
}
我的问题是我无法做到
node = gpnode(src.node);
因为gpnode是一个虚拟类。我能做到
node = unode(src.node);
但是当unode的子节点是bnode时,这不起作用。如何让它智能地调用我需要它的复制构造函数?
答案 0 :(得分:11)
您需要实施克隆。
class base
{
public:
virtual base* clone() const = 0;
}
class derived : public base
{
public:
derived(){}; // default ctor
derived(const derived&){}; // copy ctor
virtual derived* clone() const { return new derived(*this); };
};
Etceteras
答案 1 :(得分:4)
为此,您必须为对象提供clone
- 方法,该方法返回适当类型的指针。如果所有类都有copy-constructors,那就简单了:
node* clone() const {
return new node(*this);
}
node
是您正在编写clone
- 方法的类。您当然必须在基类中声明该方法:
virtual gpnode* clone() const = 0;
答案 2 :(得分:3)