gpt4 book ai didi

c++ - 在派生类 C++ 中避免 "Pure Virtual Function Call"

转载 作者:太空狗 更新时间:2023-10-29 20:13:38 24 4
gpt4 key购买 nike

我是 C++ 的新手,所以如果这个问题的水平有点低于这里的通常标准,我想道歉 -

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

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

这是我的代码:

基地:

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

};

派生 1:

#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;
};

派生 1 中“einkommen()”的实现:

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

Derived 2 中“einkommen()”的实现:

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

main 方法中的数组声明:

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;
}

非常感谢!

最佳答案

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

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

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

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

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

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

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

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

关于c++ - 在派生类 C++ 中避免 "Pure Virtual Function Call",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20146111/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com