本文共 1423 字,大约阅读时间需要 4 分钟。
20170812_继承与多态测试实例
在C++编程中,多态是指一个同一个名称、形状和大小的函数或函数成员,能够在不同类中被实现。以下是通过多态测试实例的分析和总结。
在对象调用中,多态并不生效。具体表现为:调用对象的函数时,直接调用该对象所属类的函数,无论该函数是否为虚函数。
base baseObject1;baseObject1.fun(); // 调用基类的非虚函数baseObject1.test(); // 调用基类的虚函数
child childObject1;childObject1.fun(); // 调用派生类的非虚函数childObject1.test(); // 调用派生类的虚函数
结论:对象调用时,函数调用的决定由对象所属类决定,与指针或静态_cast无关。
当基类指针指向基类对象时,多态不会生效。
base *p_baseObject2 = &baseObject2;p_baseObject2->fun(); // 基类p_baseObject2->test(); // 基类
结论:基类指针指向基类对象时,调用的是基类的函数成员。
当基类指针指向派生类对象时,多态会生效。
child *p_childObject2 = &childObject2;p_childObject2->fun(); // 派生类p_childObject2->test(); // 派生类
结论:基类指针指向派生类对象时,调用的是派生类的虚函数。
上行转换允许将派生类指针转换为基类指针,以下是示例:
child childObject4;child *p_childObject4 = &childObject4;base *p_baseObject4 = static_cast(p_childObject4);p_baseObject4->fun(); // 基类p_baseObject4->test(); // 派生类
结论:上行转换会导致基类指针调用基类的非虚函数,而派生类的虚函数仍然由派生类对象决定。
下行转换需要显式强制转换,且编译器不支持隐式转换。
child childObject5;base *p_baseObject5 = &childObject5;child *p_childObject5 = static_cast(p_baseObject5);p_childObject5->fun(); // 派生类p_childObject5->test(); // 派生类
结论:下行转换会强制将基类指针转换为派生类指针,调用派生类的函数成员。
多态在C++中通过虚函数实现,函数调用的决定取决于以下因素:
以上实例通过不同方式展示了多态的特性和行为,帮助理解多态在C++中的应用。
转载地址:http://pzck.baihongyu.com/