2012-03-13 7 views
7

Ho un insieme di classi simili:C++ evitando manualmente chiamando funzione della classe base

class A { 
public: 
    int DoIt() { 
    //common code 
    } 
}; 

class B : public A { 
    int DoIt() { 
    if (A::DoIt() == 1) { 
     return 1; 
    } 
    else { 
     // do b specific code 
    } 
    } 
}; 

class C : public A { 
    int DoIt() { 
    if(A::DoIt()==1) { 
     return 1; 
    } 
    else { 
     // do c specific code 
    } 
    } 
}; 

c'è un modo per evitare manualmente mettendo questo codice:

if (A::Doit() == 1) { return 1; } else { 

in ogni classe che è derivato da A?

+1

La sintassi corretta è 'classe B: pubblico A'. C++ non è Java. – kennytm

+0

@Justin ᚅᚔᚈᚄᚒᚔ: OP sta chiedendo come evitare di digitare 'if (A :: Doit() == 1) restituisce 1; } else {'in ogni sottoclasse, non come chiamare' A :: Doit() 'senza conoscere A. La domanda collegata non è nemmeno correlata all'ereditarietà. – kennytm

risposta

9

Basta separare il codice specifico con un altro metodo metodo virtuale.

class A 
{ 
public: 
    int DoIt() /*final*/ 
    { 
     // common code 
     if (return_value == 1) 
      return 1; 
     else 
      return DoIt_specific(); 
    } 

private: 
    virtual int DoIt_specific() = 0; 
    //^or some "A"-specific actions if A cannot be abstract. 
}; 

class B : public A 
{ 
    virtual int DoIt_specific() /*override*/ 
    { 
     // specific code for B 
    } 
}; 

Questo è noto come idioma non-virtual interface.

Problemi correlati