求解释这串代码为什么输出的是236不是96?

#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()为啥不对?

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

输出结果如图:

img


这个时候就会发现,调用的全是子类的。
而题主上述所写的,会先调用父类的show再调用子类的print
希望对题主有所帮助,望采纳!!

因为你的show不构成多态。建议再去看看虚函数重写的条件。。。