2013-05-09 20 views
5

Mam do czynienia z dziedziczeniem w C++. Chciałem napisać program dodawania i odejmowania dwóch tablic. Herezje mój kod:Niezdefiniowane odniesienie do "typeinfo for class" i niezdefiniowane odniesienie do "vtable for class"

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

Ale mam dziwne błędy:

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

nie wiem skąd one pochodzą, nie teraz, jak „naprawić” im. Z góry dziękuję;)

+1

Nie należy używać gołych wskaźników. Po prostu nie idź tam. To jest okropnie zepsuty kod. (Sprawdź również, jak działają listy inicjalizacyjne konstruktora.) –

Odpowiedz

12

root::setSize nie jest zadeklarowana czysto wirtualne, co oznacza, że ​​muszą być zdefiniowane. Można przypuszczać, że powinna ona być czysta jak inne funkcje:

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

Jeśli jesteś zainteresowany w krwawych szczegółów dlaczego masz ten konkretny błąd: to kompilator musi generować wirtualny metadane/RTTI przez klasę gdzieś i, jeśli klasa deklaruje nie-czystą, nieliniową funkcję wirtualną, wygeneruje ją w tej samej jednostce tłumaczeniowej, co definicja tej funkcji. Ponieważ nie ma definicji, nie są generowane, dając ten błąd.

+1

+1 za podanie krwawych szczegółów! – Nick

1

Twoja root::setSize nie została zdefiniowana i nie została zadeklarowana jako czysta funkcja wirtualna. Albo dodaj = 0 do końca funkcji (czyniąc ją czystym virtalem), albo zdefiniuj funkcję root::setSize.

1

wierzę, że to dlatego, że nie wdrożyły

virtual void setSize(int); 

w root lub zadeklarowanej to jak czysta wirtualny dodając =0

Powiązane problemy