c++支持多态性的几种方式:
1、通过一个隐式转化,从“派生类指针或引用”转化到“其公有基类类型的指针或引用”
Query *pquery = new NameQuery( "Glass" );
2、通过虚拟函数机制
3、通过dynamic_cast 和 typeid 操作符(RTTI)
1)首先这两个操作符是在“运行时刻类型识别”!
2)当一个类库是由第三方库提供商提供时,此时我们不能增加虚拟成员函数。但我们可能仍然希望扩展这个类库(以便增加类库的功能),这种情况下,就必须使用dynamic_cast。
使用dynamic_cast时注意:
如果转化的类型为派生类指针,这样使用:
void Company::payroll( employee *pe )
{
if( programmer *pm = dynamic_cast< programmer * >( pe ))
{
//使用pm
}
else
{
//使用employee的成员函数
}
}
如果转化的类型为派生类引用,这样使用:
#include <typeinfo>
void Company::payroll( employee &pe )
{
try
{
programmer &pm = dynamic_cast< programmer & >( pe );
//使用pm
}
catch( std::bad_cast )
{
//使用employee的成员函数
}
}
使用typeid时:
当typeid的操作数为“类类型”,但不是带有虚拟函数的类类型时,typeid操作符会指出当前操作数的类型:
例如:
class Base{/*没有虚拟函数*/};
class UserBase : public Base {};
UserBase user;
Base *pb = &user;
typeid(*pb).name()的值为Base//如果基类中有虚拟函数,则结果为UserBase
Base &rb = user;
typeid(rb).name()的值为Base//如果基类中有虚拟函数,则结果为UserBase
当typeid的操作数为“类型指针时”返回的结果是操作数的类型,例如:
typeid(&rb).name()的值为Base *
typeid(pb).name()的值为Base *