1 / 9
文档名称:

强制转型.docx

格式:docx   大小:20KB   页数:9页
下载后只包含 1 个 DOCX 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

强制转型.docx

上传人:kunpengchaoyue 2022/5/10 文件大小:20 KB

下载得到文件列表

强制转型.docx

相关文档

文档介绍

文档介绍:dynamic_cast
运算符dynamic_cast可以针对两种数据类型做强制转换:指针类型和引用类型。这两种类型的情况是不一样的。下面讨论如下:
1、对指针的强制转换
dynamic_cast<T*>(p);
如果p的类型为T模块的所有VCL控件,如果可以动态转换成数据集类型(TDataSet),则调用TDataSet的Open()方法打开它。
//void__fastcallTDM::DataModuleCreate(TObject*Sender)
{
inti;
TDataSet*p;
for(i=0;i<ComponentCount;i++)if(p=dynamic_cast<TDataSet*>(Components[i]))
p->Open();
}
//
标准C++中有四个类型转换符。
1、static_cast,支持子类指针到父类指针的转换,并根据实际情况调整指针的值,反过来也支持,但会给出编译警告,它作用最类似C风格的“强制转换”,一般来说可认为它是安全的;
2、dynamic_cast,支持子类指针到父类指针的转换,并根据实际情况调整指针的值,和static_cast不同,反过来它就不支持了,会导致编译错误,这种转换是最安全的转换;
3、reinterpret_cast,支持任何转换,但仅仅是如它的名字所描述的那样“重解释”而已,不会对指针的值进行任何调整,用它完全可以做到“指鹿为马”,但很明显,它是最不安全的转换,使用它的时候,你得头脑清醒,知道自己在干什么;
4const_cast,这个转换能剥离一个对象的const属性,也就是说允许你对常量进行修改。
作为四个内部类型转换操作符之一的dynamic_cast和传统的C风格的强制类型转换有着巨大的差别。除了dynamic_cast以外的转换,其行为的都是在编译期就得以确定的,转换是否成功,并不依赖被转换的对象。而dynamic_cast则不然。在这里,不再讨论其他三种转换和C风格的转换。
首先,dynamic_cast依赖于RTTI信息,其次,在转换时,dynamic_cast会检查转换的source对象是否真的可以转换成target类型,这种检查不是语法上的,而是真实情况的检查。
先看RTTI相关部分,通常,许多编译器都是通过vtable找到对象的RTTI信息的,这也就意味着,如果基类没有虚方法,也就无法判断一个基类指针变量所指对象的真实类型,这时候,dynamic_cast只能用来做安全的转换,例如从派生类指针转换成基类指针
.而这种转换其实并不需要dynamic_cast参与.
也就是说,dynamic_cast是根据RTTI记载的信息来判断类型转换是否合法的.
下面看一个例子:
structB1{
virtual~B1(){}
};
structB2{
virtual~B2(){}
};
structD1:B1,B2{};
intmain()
{
D1d;
B1*pb1=&d;
B2*pb2=dynamic_cast<B2*>(pb1);//L1
B2*pb22=static_cast<B2*>(pb1);//L2return0;
}
上述定义中可以看到,B1和B2是不相关的类,从L1可以看