【发布时间】:2012-05-17 10:51:57
【问题描述】:
OnUpdate 的第三个参数是指向CObject 的指针。指针必须在实现自己的OnUpdate 的视图类中向下转换。检查演员表是否成功的最佳方法是什么?使用CObject::IsKindOf 还是dynamic_cast?在 MFC 项目中使用 RTTI 可以吗?
【问题讨论】:
OnUpdate 的第三个参数是指向CObject 的指针。指针必须在实现自己的OnUpdate 的视图类中向下转换。检查演员表是否成功的最佳方法是什么?使用CObject::IsKindOf 还是dynamic_cast?在 MFC 项目中使用 RTTI 可以吗?
【问题讨论】:
如果您使用向导创建了视图,那么它将在您的视图类的头文件中放置一个 DECLARE_DYNCREATE。如果你手动创建它,我会确保它在你的视图头文件的类定义中有一个 DECLARE_DYNCREATE(或者至少一个 DECLARE_DYNAMIC 或 DECLARE_SERIAL——DECLARE_SERIAL 对于视图类来说通常是多余的)。
那么,当您想要向下转换时,请使用 DYNAMIC_DOWNCAST 宏并在返回时测试非 NULL。
CView* pView = DYNAMIC_DOWNCAST(CView, pObject); // 是一种用法
不要听信不使用 MFC 宏的建议,因为它不可移植……如果您正在编写 CView 派生类,它已经不可移植——除非您使用 Wind/U 之类的工具包,然后DYNAMIC_DOWNCAST 也将是可移植的。
【讨论】:
CObject::IsKindOf() 仅在使用 DECLARE_DYNAMIC、DECLARE_DYNCREATE 或 DECLARE_SERIAL(CView 声明它们)声明类但不需要 RTTI 支持时才有效。
虽然dynamic_cast 与 RTTI 支持一起工作,但它包含一些开销并且可执行文件大小略有增加,check this..
【讨论】:
我在工作中使用 dynamic_cast 并且没有任何问题。 检查施法成功非常简单: CDerivedView* pView = dynamic_cast(pViewObj); 如果(!pView){断言(0);返回; }
此外,我们尽量不使用 MFC 的宏,因为它们是不可移植的 - 就像 MFC 本身一样。 我认为,好的程序不能几乎依赖于它所使用的库。
【讨论】: