注册 登录
编程论坛 C++教室

关于对象多态的类型转换

后卿 发布于 2023-05-11 11:30, 56 次点击
程序代码:

wolfman peter{};
void *ptr   = &peter;
wolf *pwolf = (wolf*)ptr;
man  *pman  = (man*)ptr;

已知wolf(狼)、man(人)为父类,wolfman(狼人)同时继承了它们两个
这里的ptr是一个无类型的指针,也就是它就是一个单纯的值
第三行代码把这个值显示转成wolf*,类型发生了变化,第四行把这个值转成man*,类型也发生了变化,
但为什么这里pwolf和pman的值是一样的呢?它们的类型明明不一样
1 回复
#2
rjsp2023-05-11 18:52
为什么这里pwolf和pman的值是一样的呢?
我给你一个 void* 类型的指针 ptr,指针值为 0x10000000。也就是你不知道它是不是一个int类型的地址、float类型的地址、wolf类型的地址、man类型的地址、wolfman类型的地址、……
现在你告诉我 (wolf*)ptr 的值是多少?0x10000000吗?0x10000001吗?0x10000002吗?……


你的 (wolf*)ptr 等同于 reinterpret_cast<wolf*>(&peter),是错误的转换;
而 (wolf*)(wolfman*)ptr 等同于 static_cast<wolf*>(&peter),是正确的,但前提是确保 wolfman 是 ptr所指动态类型 的本尊或其基类,并且确保 wolf 是 ptr所指动态类型 的本尊或其基类;
reinterpret_cast<wolf*>(&peter) 则更为安全,若 接受类型 并非 所指动态类型 的本尊或其基类,将返回 nullptr。
1