首页 > 代码库 > mfc 类型间的强制转换
mfc 类型间的强制转换
一、 static_cast运算符 用法:static_cast < type-id > ( expression ) 该运算符把expression 转换为type-id类型,但没有运行时类型检查来保证转换的安全性。它主要有如下几种用法: ①用于类层次结构中基类和子类之间指针或引用的转换。 进行上行转换(把子类的指针或引用转换成基类表示)是安全的; ②用于基本数据类型之间的转换,如把int转换成char,把int转换成enum。这种转换的安全性也要开发人员来保证。 ③把空指针转换成目标类型的空指针。 ④把任何类型的表达式转换成void类型。 注意:static_cast不能转换掉const、volitale、或者__unaligned属性。 二、 dynamic_cast 运算符 用法:dynamic_cast < type-id > ( expression ) 该运算符把expression 转换成type-id类型的对象。Type-id必须是类的指针、类的引用或者void *; 如果type-id是类指针类型,那么expression 也必须是一个指针,如果type-id是一个引用,那么expression 也必须是一个引用。 dynamic_cast主要用于类层次间的上行转换和下行转换,还可以用于类之间的交叉转换。 在类层次间进行上行转换时,dynamic_cast和static_cast的效果是一样的; 进行下行转换(把基类指针或引用转换成子类表示)时,由于没有动态类型检查,所以是不安全的。 (由子类转基类) 上行 ,或者叫由宽变窄 (基类转派生类)下行 ,由窄变宽 三、reinterpret_cast运算符 用法:reinterpret_cast<type-id> (expression) type-id必须是一个指针、引用、算术类型、函数指针或者成员指针。它可以把一个指针转换成一个整数,也可以把一个整数转换成一个指针(先把一个指针转换成一个整数,在把该整数转换成原类型的指针,还可以得到原先的指针值)。 该运算符的用法比较多。 四、const_cast 运算符 用法:const_cast<type_id> (expression) 该运算符用来修改类型的const或volatile属性。除了const 或volatile修饰之外, type_id和expression的类型是一样的。常量指针被转化成非常量指针,并且仍然指向原来的对象;常量引用被转换成非常量引用,并且仍然指向原来的对象;常量对象被转换成非常量对象。
代码
#include "stdafx.h" #include "B.h" #include "X.h" int _tmain(int argc, _TCHAR* argv[]) { CA a; CB b;//b继承于a类 CX x; a=b; //b=a; //a=reinterpret_cast<CA>(x); //a=(CA)x; CA *pa; CB *pb; CX *px; pa=static_cast<CA*>(&b); //pa=&b; 不提倡 pa=dynamic_cast<CA*>(&b); //pb=static_cast<CB*>(&x);//不安全 能检测到错误,要转换2个类型,不存在继承关系 pb=reinterpret_cast<CB*>(&x);//C++强制转换方式 pb=(CB*)&x;//C语言 强制转换方式 printf("&a=%x\n",&a); printf("pb=%x\n",pb); pb=dynamic_cast<CB*>(&a);//不安全 ,一般检测返回指针值是否为NULL printf("pb=%x\n",pb); getchar(); return 0; }
mfc 类型间的强制转换
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。