敬业的IT人 >> 编程开发 >> C/C++ >> C++中的向上类型转换和向下类型转换

C++中的向上类型转换和向下类型转换

敬业的IT人 互联网 佚名 2008-1-3 19:19:37

推介 :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来判断两个类是否存在继承关系。

进入讨论组讨论。
粤ICP备06119539号
Copyright CiscoSky.Org,Some Rights Reserved.
Email:me1228#tom.com