在派生类C ++中避免“纯虚函数调用”

时间:2013-11-22 13:29:22

标签: c++ inheritance virtual

我是C ++的新手,所以如果这个问题的级别略低于通常的标准,我还是要道歉 -

我试图让几个类从具有虚函数定义的基类继承,然后我想创建一个MainClass *数组,它可以包含所有派生类的顺序输出派生+定义的虚函数。

我收到错误" R6025:纯虚函数调用" - 我不知道为什么,我假设 - 当被调用时 - 使用子类中该函数的更新定义。

这是我的代码:

基地:

class mitarbeiter
{
public:
    mitarbeiter(string name, int nummer);
    ~mitarbeiter(void);
    virtual void einkommen() = 0;
protected:
    string name;
    int nummer;

};

Derived1:

#include "mitarbeiter.h"
class lohnempfaenger : public mitarbeiter
{
public:
    lohnempfaenger(int stundenlohn, int anzahlStunden, string name, int nummer);
    ~lohnempfaenger(void);
    void einkommen();
private:
    int stundenlohn;
    int anzahlStunden;
};

派生2:

#include "mitarbeiter.h"
#include <string>
class angestellter : public mitarbeiter
{
public:
    angestellter(int gehalt, string name, int nummer);
    ~angestellter(void);
    void einkommen();
private:
    int gehalt;
};

&#34; einkommen()&#34;的实施在派生1:

void lohnempfaenger::einkommen()
{
    cout << "Lohnempfaenger, Name: " << this->name << ", Gesamtlohn: " << this->stundenlohn*this->anzahlStunden << "\n";
}

&#34; einkommen()&#34;的实施在Derived 2中:

void angestellter::einkommen()
{
    cout << "Angestellter, Name: " << this->name << ", Einkommen: " << this->gehalt << "\n";
}

主要方法中的数组声明:

mitarbeiter* mitPtr[5];
mitPtr[0] = &angestellter(/*values...*/);
//error
mitPtr[0]->einkommen();

构造

mitarbeiter::mitarbeiter(string name, int nummer)
{
    this->name = name;
    this->nummer = nummer;
}

angestellter::angestellter(int gehalt, string name, int nummer):mitarbeiter(name, nummer)
{
    this->gehalt = gehalt;
}

lohnempfaenger::lohnempfaenger(int stundenlohn, int anzahlStunden, string name, int nummer):mitarbeiter(name, nummer)
{
    this->stundenlohn = stundenlohn;
    this->anzahlStunden = anzahlStunden;
}

非常感谢!

2 个答案:

答案 0 :(得分:7)

现在你已经向我们展示了你如何实际初始化指针,这就是问题所在:

mitPtr[0] = &angestellter(/*values...*/);

指向临时对象,该对象在语句结束时被销毁。之后使用指针将给出未定义的行为。

您需要一个非临时变量来指向:

angestellter a(/*values...*/);
mitPtr[0] = &a;

或者可能是动态分配的对象:

mitPtr[0] = new angestellter(...);

在这种情况下,不要忘记删除它;并且不要忘记给基类一个虚拟析构函数,以便删除它。您可以考虑使用智能指针为您删除它; std::unique_ptr将是理想的。

答案 1 :(得分:0)

我猜你在运行时看到的错误信息是说正在调用mitarbeiter :: einkommen()。

你的主要代码声称要分配一个新的angestellter,你的代码没有提供,但是有几个可能隐藏的地方。

如果mitarbeiter :: mitarbeiter调用einkommen(),无论你指定什么类型的新的,你都会得到mitarbeiter :: einkommen()。这似乎是最有可能的地方。

其他可能性是在angestellter :: angestellter()或angestellter :: einkommen()中显式调用完全限定的mitarbeiter :: einkommen()。