类型转化安全性问题

来源:互联网 发布:洛奇英雄传自我优化 编辑:程序博客网 时间:2024/05/28 23:09


dynamic_cast ,      static_cast ,     reinterpret_cast

(1reinterpret_cast

    主要是将数据从一种类型的转换为另一种类型。所谓通常为操作数的位模式提供较低层的重新解释也就是说将数据以二进制存在形式的重新解释。

比如:  

int i;char *p = "XJTU";

i = reinterpret_cast<int>(p);

此时结果,ip的值是完全相同的。reinterpret_cast的作用是说将指针p的值以二进制(位模式)的方式被解释为整型,并赋给i也是指针,整型指针;一个明显的现象是在转换前后没有数位损失。

(2)static_cast

    用法:static_cast < type-id > ( expression )

该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性。它主要有如下几种用法:  

用于类层次结构中父类和子类之间指针或引用的转换。  

进行上行转换(把派生类的指针或引用转换成基类表示)是安全的;  

进行下行转换(把基类指针或引用转换成派生类表示)时,由于没有动态类型检查,所以是不安全的。  

用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。  

把空指针转换成目标类型的空指针。  

把任何类型的表达式转换成void类型。 

比如例子:

int i;

float f = 122.5f;

i = static_cast<int>(f);

此时结果,i的值为122。

(3)dynamic_cast

在类层次间进行上行转换时,dynamic_caststatic_cast的效果是一样的;  

在进行下行转换时,dynamic_cast具有类型检查的功能,比static_cast更安全。

根据以上分析可以在消息类型转换上选择dynamic_cast合适的转换策略。

原创粉丝点击