C ++"纯虚方法叫做#34;使用抽象基类

时间:2017-07-03 23:03:44

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

我使用的是一个只有纯虚方法的抽象基类,在C ++中有一个接口行为(是的,我来自Java)。 就我的研究而言,这似乎是要走的路。

我必须抽象基类,GraphReader和Graph。

class Graph{
   public:
   Graph() {};
   virtual ~Graph() {};
   virtual void layout() = 0;
   virtual std::vector<std::shared_ptr<Node>> getNodes() = 0;
   virtual std::vector<std::shared_ptr<Edge>> getEdges() = 0;

   protected:

};

class GraphReader{
   public:
   GraphReader(std::string fileName_) :
         fileName(fileName_) {};
   virtual ~GraphReader() {};
   virtual Graph* read() = 0;

   protected:
   std::string fileName;
};

这两个都有从GraphReader / Graph继承的派生类。

class OgdfGraph : public Graph{
   public:
   OgdfGraph();
   virtual ~OgdfGraph();
   void setOgdfGraph(ogdf::Graph &oGraph);
   std::vector<std::shared_ptr<Node>> getNodes();
   std::vector<std::shared_ptr<Edge>> getEdges();
   void layout();

   private:
   [...]

};

class OgdfGmlReader : public GraphReader {  
   public:
   OgdfGmlReader(std::string fileName);
   virtual ~OgdfGmlReader();
   Graph* read();    
};

使用read()函数返回Graph *值,如下所示:

Graph* OgdfGmlReader::read() {

   [...]

   OgdfGraph og;
   og.setOgdfGraph(G);
   Graph* graph = &og;

   return graph;
}

在我的主要内容中,我执行以下操作:

   OgdfGmlReader tr = OgdfGmlReader("../data/lesmiserables.gml");
   GraphReader* gr = &tr;
   Graph* graph = gr->read();

   graph->layout();

图形的加载有效,但是当我在图形上调用布局函数时,我得到以下错误(在运行时,它编译):

pure virtual method called
terminate called without an active exception
Aborted (core dumped)

这个问题是否来自于我返回Graph的事实,并且我没有像使用GraphReader那样直接将派生类分配给其父类? 我最困惑的是因为它适用于GraphReader而不适用于Graph(从GraphReader返回),因为它与我的理解完全相同。

非常感谢任何帮助如何解决这个问题(同时可能维护继承架构)!

非常感谢你!

1 个答案:

答案 0 :(得分:5)

问题出在Read函数:

OgdfGraph og的实例是从Read函数返回的分配给graph的局部变量。请注意,变量og将超出范围,并在Read函数执行后删除。因此graph将只是一个指向Graph *的指针,而没有任何有效的实例分配给它。

您可以将OgdfGraph og更改为OgdfGraph* pog = new OgdfGraph()

来解决此问题