#include
using namespace std;
class Base{
protected:
int a,b;
public:
Base(int x=2,int y=3){ a=x; b=y; }
virtual void show() { cout<<a<<b; }
virtual void print() { cout<<a+b; }
};
class Derived:public Base{
public:
void show(int n=4) { cout<<a+b+n; }
void print() { cout<<a*b; }
};
int main(void)
{
Base *p=new Derived;
p->show();
p->print();
delete p;
system("pause");
return 0;
}
我认为这是定义了一个基类指针,指向派生中重写的show()和基类中的print()为啥不对?

求解释这串代码为什么输出的是236不是96?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注
Virtual关键字的函数就是虚拟函数,例如代码中的函数show、print,于是在Base的派生类Derived中就可以通过重写虚拟函数来实现对基类虚拟函数的覆盖。当基类Base的指针p指向派生类Derived的对象时,对p的print函数的调用实际上是调用了Derived的show和print函数而不是Base的show和print函数。这是面向对象中的多态性的体现。
如果把Derive类中 show 函数 n=4 去掉并输出 a+b的值
代码如下:#include<iostream> using namespace std; class Base{ protected: int a,b; public: Base(int x=2,int y=3){ a=x; b=y; } virtual void show() { cout<<a<<b; } virtual void print() { cout<<a+b; } }; class Derived:public Base{ public: void show() { cout<<a+b; } void print() { cout<<a*b; } }; int main(void) { Base *p=new Derived; p->show(); p->print(); return 0; }
输出结果如图:
这个时候就会发现,调用的全是子类的。
而题主上述所写的,会先调用父类的show再调用子类的print
希望对题主有所帮助,望采纳!!本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报