C ++继承和转换

时间:2015-10-24 08:15:37

标签: c++ inheritance casting

我在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();

1 个答案:

答案 0 :(得分:3)

首先,您似乎从课外分配给受保护的成员Hijo,这是不好的做法和/或不起作用。你应该使用一个setter来代替imho。

其次,您的核心问题是继承层次结构中的向下转换:您有一个指向基类的指针,并希望使用它,就像它是一个指向派生类的指针。原则上,这是完全可能的。有两种选择:

  • 如果您确定指向基类的实际指向派生类的某个对象,请使用static_cast
  • 否则请使用dynamic_cast。这需要RTTI编译但是安全并且如果指针无法转换则返回空指针。

如上面的评论中所述,您的设计可能看起来很糟糕。也许考虑使用virtual函数。