C++中的向上类型转换和向下类型转换
推介 :http://www.vlan9.com
- 程序宝典:C++学习感想
- 轻轻松松学习C++ 标准模板库STL
- C++词汇解析集锦 编程开发人员必备
- VC++学习:用vc实现生产者消费者问题
- 用VC++编写扫雷游戏
- 精华:C++编程新手错误语录(续一)
- 在VC++中生成伪随机数祥解
- C++初学者应该关心的优秀图书一览
- 最常见的20种VC++编译错误信息集合
- C++ STL编程轻松入门
【引自雁南飞的博客】在C++的世界中有这样两个概念,向上类型转换,向下类型转换,分别描述的是子类向基类和基类向子类的强制类型转换。
向上强制类型转换
切割:覆盖方法和子类数据丢失的现象生成切割(slice)。
class Base
{
public:
int b;
virtual void Test()
{
cout << "base" <<endl;
}
};class Derived:public Base
{
public:
int d;
virtual void Test()
{
cout << "derived" <<endl;
}
};int main()
{
Derived d;
Base b = d;//直接赋值(产生切割)
b.Test();Base& b2 = d;//使用引用赋值(不产生切割)
b2.Test();Base* b3 = &d;//使用指针赋值(不产生切割)
b3->Test();
return 1;
}
因此,我们得出结论,在向上强制转换过程中,使用指针和引用不会造成切割,而使用直接赋值会造成切割。
向下强制类型转换
使用dynamic_cast进行向下强制类型转换。使用此关键字有一下几个条件:
1、必须有虚函数;
2、必须打开编译器的RTTI开关(vc6: progect-> settings -> c/c++tab ->category[c++ language]-> Enable RTTI);
3.必须有继承关系。
Base *b = new Derived;
Derived *d = dynamic_cast<Derived*>(b);
if(!d)
{
cout << "dynamic cast err!"<<endl;
}
else
{
d->Test();
}
本例子中,符合以上条件,转换成功。否则,会抛出std::bad_cast异常,转换返回NULL。
因此,我们可以使用dynamic_cast来判断两个类是否存在继承关系。
进入讨论组讨论。- 最新文章
- 新手看招 Linux操作系统下C++编程初探[01-03]
- 用C语言编写Windows服务程序的五个步骤[01-03]
- Visual C++实现Flash动画播放[01-03]
- TCP/IP Winsock编程要点[01-03]
- C++ 虚基类[01-03]
- COM 组件设计与应用(一)起源及复合文件[01-03]
- 相关文章
