这是问题所在:尝试编译时,我不断收到未实现的纯虚方法错误。我已经在抽象基类中实现了所有纯虚方法。有任何想法吗?
这是抽象基类:
class record{
public:
virtual int getID()=0;
virtual record *clone();
};
和实现:
class sdata: public record{
public:
sdata(std::string s = ""){data=s; ID=atoi(data.substr(0,8).c_str());}
virtual int getID(){return ID;}
private:
std::string data;
int ID;
};
抱歉,这是完整的错误消息:
'record'中未实现的纯虚拟方法'getID'
也许这段代码会导致错误:
int hashTable::hash(record *x) {
return floor(m * (x->getID() * A - floor(x->getID() * A)));
}
最佳答案
如果没有看到导致错误的代码,就很难确切知道发生了什么。如果这是编译时错误,我在这里看不到任何会导致它的错误。
但是,如果遇到运行时错误,我可以想到的两个最常见的原因是:
(1)从基类的构造函数或析构函数内调用成员函数(甚至间接调用)。
(2)派生类在未实现的情况下调用函数的基类版本。
显示这两个错误的示例为:
struct Base {
Base()
{
call_foo(); // Oops, indirectly calls Base::foo() (Scenario 1)
}
void call_foo() const {
foo();
}
protected:
virtual void foo() const = 0;
};
struct Derived : Base {
protected:
virtual void foo() const {
Base::foo(); // Oops, unimplemented virtual base function (Scenario 2)
}
};
int main() {
Derived().call_foo();
}
==更新:可能的编译时错误==
我在您的示例代码中观察到,记录具有返回
record *
的非纯虚拟clone()成员函数。由于记录是抽象的,因此您不能直接创建记录(只能创建其具体的子类)。这表明您的clone()成员函数可能也应该是纯虚拟的。如果尝试(例如)return new record()
,您将收到一个错误,指出您的基类具有纯虚函数。