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;
}
时间: 2024-10-07 02:28:47

mfc 类型间的强制转换的相关文章

从具体化“System.Data.Objects.MaterializedDataRecord”类型到“XXXX”类型的指定强制转换无效。

在EF里面使用CreateQueryl的时候出现异常 这是原来有问题的代码 se.CreateQuery<Departments>("SELECT Departments.dId, Departments.dName, Departments.dManager FROM Departments") .ToList().ForEach(w => { System.Console.WriteLine(w.dId + " " + w.dName + &q

指针类型之间的强制转换

#include<stdio.h> void f(void *t) { int *p=(int *)t;//这一步是必须的 printf("%d",*p);//123456 } int main() { int a=123456; f(&a); return 0; } #include<stdio.h> int main() { int a=0x123456; char *p=(char *)&a; printf("%x\n"

《C#高级编程》【第7章】运算符与类型强制转换 -- 学习笔记

       运算符编程语言的基本元素,它使得我们的代码更加的简洁明了.然而我们为了解决操作数类型不同的问题,我们又有引入了强制转换的概念.我们先看看本章的内容构成吧. 1.运算符 我们来看看一些常见的运算符: <1>条件运算符 其语法如下: Condition ? true_Expression : false_Expression 当条件Condition为真时,其将执行true_Expression,否则执行false_Expression. <2> checked 和

[C/C++]_[使用dynamic_cast 强制转换的优点]

场景: 1. C++引入了dynamic_cast 这种类型识别的强制转换,对识别错误的程序是有好处的,建议能用的地方就用,它能在转换错误时返回0或抛出异常,比起C的旧强制转换 执行转换了不对类型依旧不会报错可靠些,因为这类错误如果发生了,其实很难找出来. 好处: 1.用在多态的子类情况下,父类不能提供处理接口,这时可以针对子类做特殊的处理. 2.dynamic_cast比另外3个cast优势就是会对转换进行检查,如果出错,会报错. 补充一个知识点: 左值和右值 (摘录自C++ Primer 3

PHP强制转换类型

获取数据类型 : 1.如果想查看某个表达式的值和类型,用var_dump(). 2.如果只是想得到一个易读懂的类型的表达方式用于调试,用 gettype().3.要查看某个类型,不要用 gettype(),而用is_type() 函数. ■字符串转换为数值 当一个字符串被当作数字来求值时,根据以下规则来决定结果的类型和值. 如果包括“.”,“e”或“E”其中任何一个字符的话,字符串被当作 float 来求值.否则就被当作整数. 该值由字符串最前面的部分决定.如果字符串以合法的数字数据开始,就用该

c语言-类型强制转换

强制转换的条件: 1.当所声明的类型不能满足所符值的变量时,需要转换声明的类型,以便能够存储变量. 例如:short存储的最大值为32767,但是所要符值大于32767时,short类型不符合,需要转换short类型.short MarSold = 61600;时就是错的. 2.丢失精度,当除以一个1.0和除以1是不同的.可能造成值的差别.整型除以整型只能得到整型,符值前先进行四舍五入后再符值.a=int/int,就算a是float但是得到是四舍五入后的值.可以将int转成float就可以得到精

【读书笔记】C#高级编程 第七章 运算符和类型强制转换

(一)运算符 类别 运算符 算术运算符 + - * / % 逻辑运算符 & | ^ ~ && || ! 字符串连接运算符 + 增量和减量运算符 ++ -- 移位运算符 << >> 比较运算符 == != < > <= >= 赋值运算符 = += -= *= /= %= &= |= ^= <<= >>= 成员访问运算符(用于对象和结构) . 索引运算符(用于数组和索引器) [] 类型转换运算符 () 条件

C++ 各种基本类型间的转换

常用的转换方法: 流转换 STL标准函数库中函数转换 流转换 流转换主要是用到了<sstream>库中的stringstream类. 通过stringstream可以完成基本类型间的转换, 1 #include<sstream> 2 3 using namespace std; 4 5 template<typename out_type, typename in_value> 6 7 out_type convert(const in_value & t){

PHP类型转换&amp;&amp;类型强制转换

获取数据类型 : 如果想查看某个表达式的值和类型,用 var_dump(). 如果只是想得到一个易读懂的类型的表达方式用于调试,用 gettype(). 要查看某个类型,不要用 gettype(),而用 is_type() 函数. ■字符串转换为数值 当一个字符串被当作数字来求值时,根据以下规则来决定结果的类型和值. 如果包括“.”,“e”或“E”其中任何一个字符的话,字符串被当作 float 来求值.否则就被当作整数. 该值由字符串最前面的部分决定.如果字符串以合法的数字数据开始,就用该数字作