我正在使用仅具有纯虚拟方法的抽象基类,以在 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 返回),因为它与我的理解完全相同。
非常感谢任何帮助如何解决这个问题(同时可能维护继承架构)!
非常感谢您!