我在C ++中有这两个类
Problema
这是我的超类
class Problema
{
protected:
string tipo;
int N;// GT1 # vertex ; SP5
int M;// GT1 # edges ; SP5
int K;// GT1 covering ; SP5
Problema *Hijo;
public:
//void readProblema(std::ifstream& file); // Lee un problema de un archivo
void Print();
Problema(std::string name);
Problema();
int geneSize(); // tama˜no del gen
float fitness(gene x); // c´alculo del fitness
std::string name; // hilera que indica el nombre del problema
void readProblema(std::ifstream& file);
Problema* getHijo(){return Hijo;}
string getTipo(){return tipo;}
int getN(){return N;}
int getM(){return M;}
int getK(){return K;}
int toint(std::string s);
};
和GT1
这是Problema
class GT1 : public Problema
{
public:
void Print();
GT1(int N,int M, int K,int **arcos);
int** getArcos(){return arcos;}
private:
int **arcos;
};
如果我想这样做,调用getArcos()
方法的正确方法是什么:
Problema *Prob= new Problema();
Prob->Hijo = new GT1(X,Y,Z);
Problema *P = Prob->getHijo();
int **arcos = (GT1)P->getArcos();
答案 0 :(得分:3)
首先,您似乎从课外分配给受保护的成员Hijo
,这是不好的做法和/或不起作用。你应该使用一个setter来代替imho。
其次,您的核心问题是继承层次结构中的向下转换:您有一个指向基类的指针,并希望使用它,就像它是一个指向派生类的指针。原则上,这是完全可能的。有两种选择:
static_cast
。dynamic_cast
。这需要RTTI编译但是安全并且如果指针无法转换则返回空指针。如上面的评论中所述,您的设计可能看起来很糟糕。也许考虑使用virtual
函数。