实现dynamic_cast

问题描述

| 以下代码产生此输出
1 is a null pointer
2 is not a null pointer
class base {};
class derived1: public base {};
class derived2: public base {};

int main() {
    base *baseptr[1];
    baseptr[0] = new derived2;
    derived1 *derptr = new derived1;
    derived1 *derivedptr1 = dynamic_cast<derived1*>(baseptr[0]);
    derived1 *derivedptr2 = dynamic_cast<derived1*>(derptr);
    cout<<((derivedptr1==0)?\"1 is null pointer\":\"1 is not a null pointer\") << endl;
    cout<<((derivedptr2==0)?\"2 is null pointer\":\"2 is not a null pointer\") << endl;
}
为什么派生ptr2仅初始化而派生ptr1不是初始化?因为两者都具有有效的右侧值。这是否与动态强制转换以及第二种情况下将强制派生的1 *强制转换为派生的1 *有关?     

解决方法

        首先,您的代码不可编译。为了将
dynamic_cast
用于除上流以外的其他操作,您需要多态类型作为指针操作数。您正在将其用于[尝试]交叉转换,并且您的类型不是多态的。 其次,如果您使类具有多态性(以便代码进行编译),那么您报告的行为实际上就是预期的行为。
derivedptr1
指针确实应该为空,因为
derived2
对象不是a5ѭ对象(并且所讨论的对象不是任何常见超对象的一部分)。交叉转换失败,因此“ 2”的结果为空指针。您还期待其他吗? 在第二种情况下(对于
derivedptr2
),您将\“ identity \”强制转换为
derived1 *
derived1 *
。类型是相同的,因此此强制类型转换基本上是无操作的。它只是评估为原始值。     ,        * dynamic_cast *用于检查向下转换的有效性。 如果指针实际上指向要转换的类型或从指向的类派生的类,则它返回有效的指针。
baseptr[0]
指向类型
derived2
。 用
dynamic_cast<derived1*>(baseptr[0]);
您正在尝试检查
basepte[0]
是否实际指向
derived1
或从其派生的类。显然,它们都不是,因此它返回
0
。 类似地,
derptr
指向类型
derived1
。 用
dynamic_cast<derived1*>(derptr);
您试图检查
derptr
是否指向
derived1
,这是正确的,因此它返回有效的指针类型,导致打印结果为Not null。 警告:正如@AndreyT正确指出的那样,
dynamic_cast
仅适用于
Polymorphic
类!