2013-05-09 15 views
5

Ho a che fare con l'ereditarietà in C++. Volevo scrivere un programma per l'addizione e la sottrazione di due array. Heres il mio codice:Riferimento non definito a `typeinfo per la classe 'e riferimento non definito a` vtable per la classe'

#include <iostream> 
#include <cmath> 
#include <sstream> 
using namespace std; 

class root 
{ 
    protected : 

      int size; 
      double *array; 

    public : 

     virtual ~root() {} 
     virtual root* add(const root&) = 0; 
     virtual root* sub(const root&) = 0; 
     virtual istream& in(istream&, root&) = 0; 

     virtual int getSize() const = 0; 
     virtual void setSize(int); 
     virtual int getAt(int) const = 0; 
}; 

class aa: public root 
{ 

    public : 

     aa(); 
     aa(int); 
     aa(const aa&); 
     root* add(const root& a); 
     root* sub(const root& a); 
     istream& in(istream&, root&){} 
     int getSize() const; 
     void setSize(int); 
     int getAt(int) const; 
}; 

class bb: public root 
{ 
public: 
    bb() { } 
    bb(const bb& b) { } 
    root* add(const root& a); 
    root* sub(const root& a); 
    istream& in(istream&, root&){} 
    int getSize() const{} 
    void setSize(int){} 
    int getAt(int) const{} 
}; 

aa::aa() 
{ 
    size = 0; 
    array = NULL; 
} 

aa::aa(int nsize) 
{ 
    size = nsize; 
    array = new double[size+1]; 
    for(int i=0; i<size; i++) 
     array[i] = 0; 
} 

root* aa::add(const root& a) 
{ 
    for (int i=0; i<a.getSize(); i++) 
     array[i] += a.getAt(i); 
    return new aa(); 
} 

root* aa::sub(const root& a) 
{ 
} 

int aa::getSize() const 
{ 
    return size; 
} 

void aa::setSize(int nsize) 
{ 
    size = nsize; 
    array = new double[size+1]; 
    for(int i=0; i<size; i++) 
     array[i] = 0; 
} 

int aa::getAt(int index) const 
{ 
    return array[index]; 
} 

root* bb::add(const root& a) 
{ 
    return new bb(); 
} 

root* bb::sub(const root& a) 
{ 

} 

int main(int argc, char **argv) 
{ 
} 

Ma ho una strana errori:

/home/brian/Desktop/Temp/Untitled2.o||In function `root::~root()':| 
Untitled2.cpp:(.text._ZN4rootD2Ev[_ZN4rootD5Ev]+0xb)||undefined reference to `vtable for root'| 
/home/brian/Desktop/Temp/Untitled2.o||In function `root::root()':| 
Untitled2.cpp:(.text._ZN4rootC2Ev[_ZN4rootC5Ev]+0x8)||undefined reference to `vtable for root'| 
/home/brian/Desktop/Temp/Untitled2.o:(.rodata._ZTI2bb[typeinfo for bb]+0x8)||undefined reference to `typeinfo for root'| 
/home/brian/Desktop/Temp/Untitled2.o:(.rodata._ZTI2aa[typeinfo for aa]+0x8)||undefined reference to `typeinfo for root'| 
||=== Build finished: 4 errors, 0 warnings ===| 

non so da dove sono venuti, Non ora come 'correzione' di loro. Grazie in anticipo;)

+1

Non utilizzare puntatori nudi. Basta non andare lì. Questo è un codice orribilmente rotto. (Inoltre, guarda come funzionano gli elenchi di inizializzatori dei costruttori.) –

risposta

12

root::setSize non è dichiarato puro virtuale, il che significa che deve essere definito. Presumibilmente, dovrebbe essere pura come le altre funzioni:

virtual void setSize(int) = 0; 
          ^^^ 

Se siete interessati ai dettagli scabrosi di perché si ottiene quel particolare errore: questo compilatore deve generare virtuale metadati/RTTI della classe da qualche parte e, se la classe dichiara una funzione virtuale non pura e non in linea, la genererà nella stessa unità di traduzione della definizione di quella funzione. Poiché non esiste una definizione, non vengono generati, dando quell'errore.

+1

+1 per dare i dettagli sanguinosi! – Nick

1

Il tuo root::setSize non è definito e non dichiarato una pura funzione virtuale. Aggiungere = 0 alla fine della funzione (rendendolo puro virtal) o definire una funzione root::setSize.

1

Credo che sia perché non avete implementato

virtual void setSize(int); 

in root o dichiarate come puro virtuale aggiungendo =0

Problemi correlati