如何解决实现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
类!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。