C++ 使用从数组类型派生的对象填充数组

tre*_*ker 1 c++ arrays polymorphism pointers derived-class

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

我怎样才能做到这一点?

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

Player ** playerArray;
Run Code Online (Sandbox Code Playgroud)

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

playerArray = new Player *[numPlayersIn];
Run Code Online (Sandbox Code Playgroud)

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

playerArray[i] = new Fickle(0);
Run Code Online (Sandbox Code Playgroud)

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

谢谢。

更新:

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

expected ';' before 'Fickle'
Run Code Online (Sandbox Code Playgroud)

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

Fickle.hpp 文件包含:

#pragma once
#include "player.hpp";

class Fickle: public Player {
public:
    // constructor
    Fickle(int initChoice){
        choice = initChoice;
    }
}
Run Code Online (Sandbox Code Playgroud)

这样可以吗?还是有问题?

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
};
Run Code Online (Sandbox Code Playgroud)

receive 方法将在 Fickle 和其他从 Player 类派生的类中被重写

更新2:

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

Player定义了一个方法receive:

virtual void receive(int otherChoice);
Run Code Online (Sandbox Code Playgroud)

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

void Fickle::receive(int otherChoice) {}
Run Code Online (Sandbox Code Playgroud)

给出错误:

no 'void Fickle::receive(int)' member function declared in class 'Fickle'
Run Code Online (Sandbox Code Playgroud)

但我不知道为什么这是因为receive是在Player类中定义的?

Jer*_*fin 5

虽然您可能应该使用向量,但动态分配的数组没有理由无法工作。这是一些有效的演示代码:

#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;
}
Run Code Online (Sandbox Code Playgroud)