1

在 C++ 中,我有一个指向 Player 对象的指针数组,并希望用 Fickle 对象填充它,其中 Fickle 是从 Player 派生的类。这是因为我想要一个通用的 Player 数组,我可以填充来自不同类的不同对象,这些对象都派生自 Player 类。

我怎样才能做到这一点?

我创建了一个指向 Player 对象的指针数组

Player ** playerArray;

然后将数组初始化为一定大小

playerArray = new Player *[numPlayersIn];

但是由于某种原因,以下内容不起作用:

playerArray[i] = new Fickle(0);

如何用 Fickle 对象填充 playerArray(Fickel 是从 Player 派生的类)?

谢谢。

更新:

我收到错误消息(在 Eclipse IDE 中):

expected ';' before 'Fickle'

我认为这可能与 Fickle 的定义有关。

Fickle.hpp 文件包含:

#pragma once
#include "player.hpp";

class Fickle: public Player {
public:
    // constructor
    Fickle(int initChoice){
        choice = initChoice;
    }
}

这没问题还是有问题?

Player 类头文件有:

class Player {
private:

public:
    int getChoice();
int choice; // whether 0 or 1
virtual void receive(int otherChoice); // virtual means it can be overridden in subclases
};

接收方法将在 Fickle 和其他从 Player 类派生的类中被覆盖

更新 2:

好的,我认为错误实际上是由于代码的不同部分造成的。

Player 定义了一个方法 receive:

virtual void receive(int otherChoice);

这应该被子类 Fickle 覆盖,但 Fickle 中的定义:

void Fickle::receive(int otherChoice) {}

给出错误:

no 'void Fickle::receive(int)' member function declared in class 'Fickle'

但我不知道为什么这是因为在 Player 类中定义了接收?

4

4 回答 4

4

虽然您可能应该改用向量,但动态分配的数组没有真正的原因不能工作。这是一些工作演示代码:

#include <iostream>

class Player {
public:
    virtual void show() { std::cout << "Player\n"; }
};

class Fickle : public Player {
public:
    virtual void show() { std::cout << "Fickle\n"; }
};

int main() {
    Player **p = new Player *[2];
    p[0] = new Player;
    p[1] = new Fickle;

    for (int i=0; i<2; i++)
        p[i]->show();

    for (int i=0; i<2; i++)
        delete p[i];
    delete [] p;
    return 0;
}
于 2010-10-01T21:13:43.550 回答
2

看起来您在 Fickle 类的末尾忘记了一个分号:

class Fickle: public Player {
    // ...
}; // <---- this semicolon

也许在别的地方。

更新 2:当您在派生类中重写虚函数时,您也必须在那里声明它。

于 2010-10-01T21:25:10.323 回答
1

如果它没有正确编译,那么您可能没有在您拥有该代码的同一源文件#include中定义的标头。Fickle通常这样的错误意味着编译器不知道是什么Fickle

于 2010-10-01T21:29:18.693 回答
0

是否Fickle有接受int或指针类型的构造函数?它是私人派生的Player吗?否则,它看起来应该可以工作。

于 2010-10-01T21:17:27.917 回答