我正在尝试理解virtual和pure-virtual在C++中的函数。我了解到,在派生类中,虚拟方法被派生类中给定的实现覆盖。
下面是我用来测试这个的代码:
#include <iostream>
using namespace std;
class Base
{
protected:
int a;
public :
virtual void modify ()
{
a=200;
}
void print ()
{
cout<<a<<"\n";
}
};
class Derived : public Base
{
int b;
public :
void modify()
{
a=100;
b=10;
}
void print ()
{
cout<<a<<"\t"<<b<<"\n";
}
};
int main ()
{
Base b;
b.modify ();
b.print ();
Derived d;
d.modify ();
d.print ();
return 0;
}产出:
200
100 10这意味着print ()也与modify ()一起被重写。
我的问题是:
那么为什么我们需要虚拟方法呢.?
发布于 2015-10-25 05:52:35
请在代码示例中考虑此情况:
Base* b = new Derived();
b->modify();
b->print();尽管b指向派生实例,但对虚拟方法b->modify的调用将正确地调用Derived::modify。但是,对b->print的调用不是声明为虚拟的,它将打印200\n,而不像在Derived::print中那样使用领先的\t char。
https://stackoverflow.com/questions/33326651
复制相似问题