2013-01-17 124 views
5

SimpleClass.h爲什麼多態在這種情況下不起作用?

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; 
} 

基類和派生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&); 

基類和派生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

什麼(特別是)不工作?你在期待什麼,這與結果有什麼不同? – iamnotmaynard

+0

print()函數在基類中是常量,但派生類中是非常量。簽名需要保持一致。 – tp1

+0

@ tp1這是正確的。我會接受你的回答。謝謝。 – Belloc

回答

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

不受

void print(std::ostream& out) 

(因爲const)覆蓋。

+4

+1。成員函數的'const'是**簽名的一部分**! – Nawaz

8

您忘記了派生類中print的定義const

5

在你DerivedClassprint()方法必須是const,就像它在BaseClass

void print(std::ostream& out) const 
相關問題