- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
在修复庞大代码库中的错误时,我观察到一个奇怪的情况,其中引用的动态类型从原始 Derived
类型更改为 Base
类型!我提供了最少的代码来解释问题:
struct Base {
// some 'virtual' function
protected: // copy constructor
private: // assignment operator
};
struct Derived : Base {
... // There are few more classes between `Base` and `Derived`
... // but for simplicity, I have put direct relation
};
void foo (Base &ref)
{
SomeClass obj;
obj.pVoid = &ref; // pVoid is of void*
// ----> typeid(ref) = Derived
(*funcptr)(obj);
// ----> typeid(ref) = Base !!!
Derived *p = dynamic_cast<Derived*>(&ref); // this fails ... i.e. "p = 0"
}
funcptr
是一个函数指针 (void (*)(SomeClass&)
)。 funcptr
可以指向这么多的函数,并且它们有自己的调用流程,因此很难调试。
很奇怪,调用函数指针后,ref
的派生类型从Derived
变成了Base
。为了简化我的工作,我怀疑对象从 Derived
切片到 Base
,所以我将 ~Base()
设为纯 virtual
并重新编译了整个源代码。但是没有编译器错误,这意味着没有声明 Base
的对象。
ref
Derived
的动态类型更改为 Base
和 dynamic_cast
的潜在原因是什么> 后来失败了?
最佳答案
我不相信上面的代码是真的,因为代码示例没有编译!您不能隐式转换 Base*
来自 dynamic_cast<Base*>(&ref)
至 Derived*
.
这就是说并假设 typeid()
的输出实际上是正确的对于引用更改的类型 ID 有一些可行的解释。所有这些都表明程序中存在某种形式的错误:
dynamics_cast<Base*>(obj.pVoid)->~Base()
的道德等价物.obj.pVoid
指向的地址构造一个新对象使用展示位置 new
,即像这样的东西:new(obj.pVoid) Base()
.Base
引用位置中的对象。就我个人而言,我会赌第二种情况是情况,即一个对象被构建到该位置。显然,如果没有看到被调用的函数,就无法分辨。
关于c++ - 在什么情况/情况下 dynamic_cast<> 会失败?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9238711/
我正在回答 question几分钟前,它向我提出了另一个问题: 在我的一个项目中,我做了一些网络消息解析。消息采用以下形式: [1 byte message type][2 bytes payload
有人说the use of dynamic_cast often means bad design and dynamic_cast can be replaced by virtual functi
在模板类中,我尝试使用 dynamic_cast 从文件中读取的字符串进行转换,并希望能够使用 bad_cast 异常捕获失败的转换。但是,在编译时(将测试程序设置为 double 作为模板类,我得到
在我的程序中,我有一个基类(ship)和四个派生类(pirate、mercantile、repairing, exploring) 和 repairing 的成员函数中我想知道 ship * 指向的对
本书The c++ programming language有关于 dynamic_cast 的部分,我不确定我是否理解正确。 The purpose of dynamic_cast is to de
这个问题在这里已经有了答案: How to write own dynamic_cast (4 个答案) 关闭 6 年前。 Stroustrup 书中的一个练习如下: Write a templat
我正在尝试确定 T* 指针指向的对象是否真的是 T 对象,或者其他一些不相关的类型。我试过 dynamic_cast,但它一点用处都没有,它返回指针本身而不是 null,即使很明显它没有指向有效的 T
在我的系统中,低层级对象通过调用+1 级层级对象的函数与高层级对象通信,调用+1 级层级对象的函数,等等,直到函数调用停止在配方处. 有一个Message抽象类,还有很多派生类,分别保存着不同种类的数
我已经对此进行了一些搜索,但只是为了确保: 使用dynamic_cast 将基类指针转换为派生类指针需要基类是多态的吗?不然连编译都编译不了? 谢谢。 最佳答案 您可以使用 dynamic_cast
class A { public: virtual void func() { cout(pa); pb->func1(); return 0; } 尽管 pb 指向一个
我有这段代码: void addLineRelative(LineNumber number, LineNumber relativeNumber) { list >::ite
我刚刚在这里读到这个问题 https://stackoverflow.com/a/332086/2689696它告诉动态类型转换 You can use it for more than just c
我的问题与 What's the point of IsA() in C++? 有关.我有一个性能关键代码,其中包含在特定位置处理来自派生类的特定函数,其中只有基指针可用。检查我们拥有哪个派生类的最佳
这个问题在这里已经有了答案: When should static_cast, dynamic_cast, const_cast, and reinterpret_cast be used? (12
我正在为我的游戏制作一个简单的图形引擎。 这是界面部分: class Texture { ... }; class DrawContext { virtual void set_texture
这件事让我沮丧了一个多星期。我已经浏览了该网站上有关 dynamic_casting 的各种主题,但我仍然不确定实现它的最佳方法是什么。 所以我有一个这样的基类: class baseClass {
我在尝试编译我的代码时遇到以下错误。 ERROR! ..\myCode\CPOI.cpp:68:41: error: cannot dynamic_cast 'screenType' (of type
请帮助我理解奇怪的行为: 我在处理析构函数~MyLogicObject()时使用dynamic_cast from MyObject to MyLogicObject,但编译器抛出异常:非 rtti_
我想了解装饰器模式是如何工作的,以及我可以在多大程度上“扩展”它以满足我的需要。正在关注this例如,我有扩展类 XYZ。存在派生类“KLM”(来自 XYZ) 具体来说,即使我有一个装饰器模式,派生的
为了好玩,我决定尝试制作一个简单的实体组件系统。我有一个包含所有组件的列表,我创建了一个名为 getPositionComponent 的函数,它获取实体 ID 并返回与该实体相关的位置组件。我制作的
我是一名优秀的程序员,十分优秀!