3

考虑以下代码:

#include<iostream>
#include<vector>

class A
{
public:
    A(int n = 0) : m_n(n) {}

public: 
    virtual int value() const {return m_n;}
    virtual ~A() {}

protected:
    int m_n;
};

class B : public A
{
public:
    B(int n = 0) : A(n){}

public:
    virtual int value() const {return m_n + 1;}
};

int main(char* args[])
{
    const A a(1);
    const B b(3);
    const A *x[2] = {&a, &b};
    typedef std::vector<A> V;
    V y;
    y.push_back(a);
    y.push_back(b);
    V::const_iterator i = y.begin();

    std::cout << x[0]->value() << x[1]->value()
        << i->value() << (i+1)->value() << std::endl;

    getchar();
    return 0;
}

为什么打印出来1413,而不是1414value()即使像(i+1)->value();.

4

2 回答 2

5

您的向量V包含A对象,因此没有动态调度的范围。你总是在打电话A::value()。对象的B一部分在复制到向量中时会被切掉。这和这样做是一样的:

B b(1);

A a1 = b;  // a1 is an A object, not a B.
a1.value();

请参阅对象切片

于 2013-10-15T15:26:14.377 回答
3

因为当你进行y.push_back(b);切片时;vector持有类型的对象A。要使用多态性,您需要引用或指针。

于 2013-10-15T15:26:22.220 回答