我正在尝试理解C ++中的PropertyTypes
和Alias
函数。我开始知道在派生类中,虚拟方法被派生类中给出的实现覆盖。
以下是我用来测试此代码的代码:
virtual
输出:
pure-virtual
这意味着#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
一起被覆盖。
我的问题:
那为什么我们需要虚拟方法......?
答案 0 :(得分:3)
请考虑您的代码示例:
Base* b = new Derived();
b->modify();
b->print();
即使b
指向Derived实例,虚拟方法b->modify
的调用也会正确调用Derived::modify
。但是,b->print
的调用(未声明为虚拟)将打印200\n
而不使用\t
中的前导Derived::print
字符。