2013-05-09 12 views
5

Ich habe es mit der Vererbung in C++ zu tun. Ich wollte ein Programm für die Addition und Subtraktion von zwei Arrays schreiben. Heres meinen Code:Undefinierter Verweis auf `typeinfo für Klasse 'und undefinierter Verweis auf` vtable für Klasse'

#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) 
{ 
} 

Aber ich habe einen seltsamen Fehler:

/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 ===| 

wissen nicht, von woher sie kam jetzt nicht, wie zu 'fix' sie. Vielen Dank im Voraus;)

+1

Verwenden Sie keine nackten Zeiger. Geh einfach nicht dorthin. Das ist schrecklich gebrochener Code. (Sehen Sie auch nach, wie Konstruktorinitialisierungslisten funktionieren.) –

Antwort

12

root::setSize ist rein virtuelle nicht erklärt, was bedeutet, es muss definiert sein. Vermutlich sollte es so rein wie die anderen Funktionen sein:

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

Wenn Sie Interesse an den blutigen Details, warum Sie bekommen, dass bestimmte Fehler: diese Compiler die Klasse des virtuellen/RTTI Metadaten irgendwo zu erzeugen braucht und, Wenn die Klasse eine nicht-reine, nichtlineare virtuelle Funktion deklariert, wird sie in der gleichen Übersetzungseinheit wie die Definition dieser Funktion generiert. Da es keine Definition gibt, werden sie nicht generiert und geben diesen Fehler an.

+1

+1 für die Angabe der blutigen Details! – Nick

1

Ihre root::setSize ist nicht definiert, und keine reine virtuelle Funktion deklariert. Fügen Sie entweder = 0 am Ende der Funktion hinzu (wodurch es pure virtual wird) oder definieren Sie eine root::setSize-Funktion.

1

Ich glaube, es ist, weil Sie nicht

virtual void setSize(int); 

in root oder erklärt es als rein virtuelle durch Zugabe implementiert haben =0