这是问题所在:尝试编译时,我不断收到未实现的纯虚方法错误。我已经在抽象基类中实现了所有纯虚方法。有任何想法吗?

这是抽象基类:

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(),您将收到一个错误,指出您的基类具有纯虚函数。

07-26 07:42