向上强制类型转换
切割:覆盖方法和子类数据丢失的现象生成切割(slice)
classBase
{
public:
intb;
virtualvoidTest()
{
cout<<\"base\"<<endl;
}
};
classDerived:publicBase
{
public:
intd;
virtualvoidTest()
{
cout<<\"derived\"<<endl;
}
};
intmain()
{
Derivedd;
Baseb=d;//直接赋值(产生切割)
b.Test();
Base&b2=d;//使用引用赋值(不产生切割)
b2.Test();
Base*b3=&d;//使用指针赋值(不产生切割)
b3->Test();
return1;
}
因此,我们得出结论,在向上强制转换过程中,使用指针和引用不会造成切割,而使用直接赋值会造成切割。
向下强制类型转换
使用dynamic_cast进行向下强制类型转换。使用此关键字有一下几个条件
1.必须有虚函数
2.必须打开编译器的RTTI开关(vc6:progect->settings->c/c++tab->category[c++language]->EnableRTTI)
3.必须有继承关系
Base*b=newDerived;
Derived*d=dynamic_cast<Derived*>(b);
if(!d)
{
cout<<\"dynamiccasterr!\"<<endl;
}
else
{
d->Test();
}
本例子中,符合以上条件,转换成功。否则,会抛出std::bad_cast异常,转换返回NULL
最新评论