C ++通过抽象基类在未知派生类上调用复制构造函数

时间:2011-10-27 07:46:04

标签: c++ inheritance copy-constructor abstract-base-class

我正在创建一个具有多种不同节点类型的树:二进制节点,一元节点和终端节点。我有一个所有节点继承的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时,这不起作用。如何让它智能地调用我需要它的复制构造函数?

3 个答案:

答案 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)