#include
using namespace std;
class B{
public:
virtual void show() { cout << "B"; }
};
class D : public B {
public:
void show() { cout << "D"; }
};
void fun1(B* ptr) { ptr->show(); }
void fun2(B& ref) { ref.show(); }
void fun3(B b) { b.show(); }
int main() {
B b, * p = new D;
D d;
fun1(p);
fun2(b);
fun3(d);
return 0;
}
答案是“DBB”,因为多态性在 C++ 中的工作方式。
在此代码中,fun1将指向类对象的指针B作为参数并调用该show方法。但是,由于p指向 类型的对象,因此将调用中D的重写show方法,从而导致输出“D”。D
fun2将对类对象的引用B作为参数并调用该show方法。在这种情况下,引用指向 类型的对象B,因此将调用show类中定义的方法B,从而产生输出“B”。
fun3按值将类的对象B作为参数并调用该show方法。在这种情况下,参数是 type 的对象D,但因为它是按值传递的,所以会创建对象的副本,并且该show副本的方法将是 class 中定义的方法B,从而导致输出“B”。