RTTI运行时类型识别与类对象的动态创建.docVIP

RTTI运行时类型识别与类对象的动态创建.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
RTTI运行时类型识别与类对象的动态创建

RTTI运行时类型识别 CRuntimeClass是MFC专用的。CRuntimeClass在文件AFX.H中声明,它是用来串起MFC从COBJECT继承下来的所有类也可以把自己写的类加入这。struct CRuntimeClass { // Attributes LPCSTR m_lpszClassName; //类名 int m_nObjectSize; //类对象大小 UINT m_wSchema; //分类编号(对不可分类的类,该值为-1)CObject* (PASCAL* m_pfnCreateObject)(); // NULL = abstract class CRuntimeClass* m_pBaseClass; //基类指针,但这里指针一定是指向父亲的,而不会指向祖父 // CRuntimeClass objects linked together in simple list static CRuntimeClass* pFirstClass; // class list的链表头。注意这个与基类指针不同。并且,该对象是个静态变量,所有CRuntimeClass对象共享 CRuntimeClass* m_pNextClass; // 链表中紧跟当前对象的下一个对象。与当前对象不一定有继承关系 }; 特别注意:该struct使用了链表的概念,但是该链表与常规的数据结构链表是不太一样的。该链表每次新加入的节点都是放在链表头上的,类似栈。所以pFirstClass是随着每次新节点的加入一直在更新的,pFirstClass必然指向新加入的节点。而m_pNextClass则指向前一个加入的节点。 如下图: 首先初始化static CRuntimeClass* pFirstClass为NULL。 最开始加入链表的是CObject。此时: 在_IMPLEMENT_RUNTIMECLASS宏中先直接设置m_pBaseClass: #m_pBaseClass= NULL; 然后在_IMPLEMENT_RUNTIMECLASS宏中调用AFX_CLASSINIT的构造函数设置m_pNextClass与pFirstClass:(这两者是先m_pNextClass后pFirstClass) #m_pNextClass= pFirstClass =NULL; #pFirstClass= CObject; 然后CCmdTarget加入链表。数据更新顺序同上: #m_pBaseClass=CObject; #m_pNextClass= pFirstClass = CObject; #pFirstClass= CCmdTarget; 接着CWinThread加入链表。数据更新顺序同上: #m_pBaseClass=CCmdTarget; #m_pNextClass= pFirstClass = CCmdTarget; #pFirstClass= CWinThread; 每一个类都拥有这样一个static的CRuntimeClass 成员变量。由于每个类都有static的CRuntimeClass 成员变量,所以每个类的对象都是引用以及修改本类的static的CRuntimeClass 成员变量,而不会将父类或者子类的修改掉。(父类与子类中的static同名成员变量是会造成“覆盖”的,该覆盖指的是引用时若不加域名直接使用,则使用的是本类的,而不会引用父类的。但实际上在内存中父类的static同名成员变量是依然存在的) 每个static的CRuntimeClass 成员变量都有一定的命名规则(在CRuntimeClass中采用的方法是在每个类的类名之前冠以class 作为它的名称,如CView的名称为classCView),然后,经由某种手段将整个类别库构造好之后,「类别型录」能呈现类似这样的风貌: 注意是每个类共享一个CRuntimeClass成员变量。 例: CCmdTarget cmd1,cmd2; CWinThread thread; 上面两个类定义了三个对象。其中: cmd1与cmd2共享一个CRuntimeClass成员变量。所以cmd1与cmd2所拥有的CRuntimeClass成员变量是同一个。 thread单独使用一个CRuntimeClass成员变量。thread所使用的这个CRuntimeClass成员变量与cmd1、cmd2共享的那个CRuntimeClass成员变量不是同一个。 pFirstClass是CRuntimeClass结构体中的static变量,所以所有的对象都共享pFirstClass。因此,cmd1、cmd2、thread三者共享CRuntimeClass结构体中的static变量pF

文档评论(0)

didala + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档