为什么多态性在这种情况下不起作用



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

基本类和派生类.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&);

基础类和派生类.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 ?
}
virtual void print(std::ostream& out) const 

未被覆盖

void print(std::ostream& out)

(因为const(。

您忘记了派生类中print定义上的const

DerivedClass中,print()方法必须是const,就像在BaseClass:中一样

void print(std::ostream& out) const

相关内容

  • 没有找到相关文章

最新更新