2013-01-17 38 views
5

SimpleClass.hBu durumda neden polimorfizm çalışmıyor?

class SimpleClass 
{ 
    int i; 

    public: 
    SimpleClass() : i(0) {} 
    SimpleClass(int j) : i(j) {} 
    friend std::ostream& operator<<(std::ostream&, const SimpleClass&); 
}; 

SimpleClass.cpp

#include <ostream> 
#include "SimpleClass.h" 

std::ostream& operator<<(std::ostream& out, const SimpleClass& obj) 
{ 
    out << "SimpleClass : " << obj.i << '\n'; 
    return out; 
} 

Tabanı ve Türetilmiş Classes.h

class BaseClass 
{ 
    protected: 
    int i; 

    public: 
    BaseClass() : i(0) {} 
    BaseClass(int j) : i(j) {} 
    virtual void print(std::ostream& out) const { out << "BaseClass : " << i << '\n'; } 
}; 

class DerivedClass : public BaseClass 
{ 
    int j; 

    public: 
    DerivedClass() : BaseClass(), j(0) {} 
    DerivedClass(int m, int n) : BaseClass(m), j(n) {} 
    void print(std::ostream& out) { out << "DerivedClass : " << i << ' ' << j << '\n'; } 
}; 

std::ostream& operator<<(std::ostream&, const BaseClass&); 

Tabanı ve Türetilmiş Classes.cpp

#include <ostream> 
#include "Base and Derived Classes.h" 

std::ostream& operator<<(std::ostream& out, const BaseClass& obj) 
{ 
    obj.print(out); 
    return out; 
} 

main.cpp

#include <iostream> 
#include "SimpleClass.h" 
#include "Base and Derived Classes.h" 

int main() 
{ 
    SimpleClass simple(10); 
    std::cout << simple; 
    BaseClass base(100); 
    std::cout << base; 
    DerivedClass derived(100, 200); 
    std::cout << derived;     // Doesn't call derived.print(), but base.print() instead. Why ? 
} 
+0

Ne (özellikle) çalışmıyor? Ne bekliyorsunuz ve bu sonuçtan nasıl farklı? – iamnotmaynard

+0

print() işlevi, temel sınıfta const, ancak türetilmiş sınıfta const değil. İmzanın aynı olması gerekiyor. – tp1

+0

@ tp1 Bu doğru. Cevabını kabul edeceğim. Teşekkürler. – Belloc

cevap

20
virtual void print(std::ostream& out) const 

(çünkü const arasında)

void print(std::ostream& out) 

geçersiz değildir.

+4

+1. Bir üye fonksiyonunun konstrüksiyonu ** imzanın bir parçasıdır **! – Nawaz

8

Türetilmiş sınıfta print tanımında const'u unutmuşsunuzdur. o BaseClass öyle gibi DerivedClassprint() yöntemde

5

, const olmalıdır:

void print(std::ostream& out) const