您当前的位置:首页 > 养生 > 内容

implement_dyncreate(请高手受累指导下IMPLEMENT_DYNCREATE 这个宏的语法结构,看不懂这段代码,书上宏定义也没有这格式)

本文目录

  • 请高手受累指导下IMPLEMENT_DYNCREATE 这个宏的语法结构,看不懂这段代码,书上宏定义也没有这格式
  • IMPLEMENT_DYNCREATE(CFileView, CView)
  • 一个vc关于创建窗口的问题,很简单
  • 火急为急:CRecordView构造函数为什么是protected成员函数啊
  • IMPLEMENT_DYNCREATE的介绍
  • vs2010拆分窗口出现中断,求助!

请高手受累指导下IMPLEMENT_DYNCREATE 这个宏的语法结构,看不懂这段代码,书上宏定义也没有这格式

和DECLEAR_DYNCREATE 一起拿个文本文件把宏复制进去,然后用查找替换功能 全部展开 最后把这些代码 复制回 原来的.h 和.cpp里编译通过(编译通过代表展开是正确的) 再理解下结构就清楚了一个是声明 一个是 定义CreateObject 是用来创建对象的函数IMPLEMENT_RUNTIMECLASS 这个应该是个创建对象的列表里面是个RuntimeClass的类的对象,RuntimeClass MSDN上没有说明的需要自己看下代码理解,对象后面有注释的。很久没去用MFC了,宏的名字 和 类的名字可能有点记错 差不多这个样子。宏里面 \ 代表换行 ## 代表连接 #代表转换为字符串比如a##b = ab#a = “a“MFC就是用这样的方式来创建对象的,而制作的时候看起来是在类里增加函数所以初学的人会弄不清方向 把 类和对象的概念弄混

IMPLEMENT_DYNCREATE(CFileView, CView)

什么宏也没有,不支持运行时类信息和序列化,但是支持诊断内存管理。DECLARE_DYNAMIC和IMPLEMENT_DYNAMIC :支持 基本功能+运行时类信息支持。DECLARE_DYNCREATE和IMPLEMENT_DYNCREATE:支持 基本功能+运行时类信息+动态创建支持。CECLARE_SERIAL:基本功能+运行时类信息+动态创建+序列化支持。

一个vc关于创建窗口的问题,很简单

mydlg-》SetWindowText(abc);//改变窗口标题“可能“和下面的内容有关,能理解多少看你自己了学mfc学到文档,视图和框架的时候,知道必须在这三个类的派生类的类声明 里加上DECLARE_DYNCREATE,然后在类声明外合适的地方加上IMPLEMENT_DYNCREA TE,然后文档,视图和框架,还有文档模板就可以协调工作了。查看msdn,发现 类似的宏有这几对: DECLARE_DYNAMIC 和 IMPLEMENT_DYNAMIC DECLARE_DYNCREATE 和 IMPLEMENT_DYNCREATE DECLARE_SERIAL 和 IMPLEMENT_SERIAL 虽然msdn里介绍了他们的作用,但对于它们为什么会起这样的作用心里却没 底,于是翻了翻mfc的源代码,喜欢钻牛角尖的人可以和我一起来钻一钻。 1。 RUNTIME_CLASS宏的定义是这样的: #define RUNTIME_CLASS(class_name) ((CRuntimeClass*)(&class_name::class##class_name)) 其中##的意思是把##两边的符号都进行宏扩展(如果它们是宏的话),然后把扩展 后的内容连接在一起,中间不加空格。例如:RUNTIME_CLASS(CView)将被扩展成 : (CRuntimeClass*)(&CView::classCView) 但这个classCView是什么意思?原来,classCView是由DECLARE_DYNAMIC(CView) 引入的一个public属性的CRuntimeClass类型的静态成员变量: static const AFX_DATA CRuntimeClass classCView; 原来RUNTIME_CLASS的作用就是引用由DECLARE_DYNAMIC宏引入的静态成员变 量。 2。DECLARE_DYNAMIC(class_name) 由于篇幅的原因,宏的具体定义代码就不列出来了,感兴趣的可以去看文件 afx.h。 该宏往类中声明了三个成员: protected: static CRuntimeClass* PASCAL _GetBaseClass(); public: virtual CRuntimeClass* GetRuntimeClass() const; static const AFX_DATA CRuntimeClass class##class_name; 有两个成员函数,一个静态成员变量class+类名,同RUNTIME_CLASS相似,如 果是DECLARE_DYNAMIC(CView)的话,这个静态成员变量将是classCView。可见这 个成员变量的名称是和DECLARE_DYNAMIC的参数有关的。在下文我们把这个成员变 量统统记做class##class_name。 这个静态成员和两个成员函数在哪里被初始化和具体实现呢?原来是在IMPL EMENT_DYNAMIC宏里。 3。IMPLEMENT_DYNAMIC(class_name, base_class_name) 查看它的宏定义,如果_AFXDLL被定义了的话,由DECLARE_DYNAMIC引入的成 员的初始化和实现是这样的: CRuntimeClass* PASCAL class_name::_GetBaseClass() { return RUNTIME_CLASS(base_class_name); } CRuntimeClass* class_name::GetRuntimeClass() const { return RUNTIME_CLASS(class_name); } AFX_COMDAT const AFX_DATADEF CRuntimeClass class_name::class##class_name = { #class_name, sizeof(class class_name), 0xFFFF, NULL, NULL, &class_name::_GetBaseClass, NULL };//这是在初始化静态成员变量class##class_name。 //CRuntimeClass结构的各个成员的意义可查看msdn。 4。_DECLARE_DYNAMIC(class_name) 该宏的定义和DECLARE_DYNAMIC(class_name)基本一样。不同之处是静态成员 class##class_name前面没有const修饰符。 5。DECLARE_DYNCREATE(class_name) 该宏也往类中引入了DECLARE_DYNAMIC宏所引入的那三个成员。除此之外,它 还另外引入了一个成员: static CObject* PASCAL CreateObject(); 该宏引入的成员在IMPLEMENT_DYNCREATE里初始化和实现。 6。IMPLEMENT_DYNCREATE(class_name, base_class_name) 该宏自然是初始化和实现由DECLARE_DYNCREATE引入的成员了。 我们看看CreateObject的实现: CObject* PASCAL class_name::CreateObject() { { return new class_name; } 呵,这个函数是如此简单,它就是用CObject类里重载的new操作符创建一个 该类类型的对象。 7。_DECLARE_DYNCREATE(class_name) 该宏引入了和DECLARE_DYNCREATE引入的四个成员差不多的成员。唯一的区别 是该宏引入的静态成员class##class_name前面没有const修饰符。 8。DECLARE_SERIAL(class_name) 该宏引入了和_DECLARE_DYNCREATE所引入的一样的四个

火急为急:CRecordView构造函数为什么是protected成员函数啊

从CView继承下来的子类很多都提供的是 protected的构造函数。你观察CFormView,CScrollView,还有构建MDI程序自动生成的CxxxView, CxxxDoc,都是保护构造函数。这样做是为了保护此类的对象不被非法构建(因为这种类有某种特殊目的——实际上也是微软的故弄玄虚而已)。只能从序列化构建(DECLARE_DYNCREATE宏来实现的,这几个类似宏也是保护的)。MDI中通过,CMultiDocTemplate对象来管理几个CRuntimeClass 对象指针,然后调用CRuntimeClass 的CreateObject来实现的对象构建。你可以跟踪CxxView的构建过程。对你的CxxxRecordView 也可以采用CRuntimeClass来完成这个工作。但是要在你的类定义前面加DECLARE_DYNCREATE,在cpp中加IMPLEMENT_DYNCREATE: 如下: CRuntimeClass * pRecordRT= RUNTIME_CLASS(CxxxRecordView);CxxxRecordView* pView = (CxxxRecordView*)pRecordRT-》CreateObject();或者在你的 CxxxRecordView中定义一个静态公共函数:mycreate,通过它来调用保护的构造函数构造一个CxxxRecordView,其实跟 CreateObject实现原理是一样的。

IMPLEMENT_DYNCREATE的介绍

IMPLEMENT_DYNCREATE通过DECLARE_DYNCREATE宏来使用IMPLEMENT_DYNCREATE宏,以允许CObject派生类对象在运行时自动建立。

vs2010拆分窗口出现中断,求助!

问题在于:RUNTIME_CLASS(CViewUp)RUNTIME_CLASS(CViewDown)要求CViewUp和CViewDown这两个类需要支持动态创建,这意味着:1,这两个类需要继承一个支持动态创建的父类,一般是CView2,需要动态创建的宏声明与定义解决思路:(与上述问题对应)1,在类定义处不要漏掉继承语句:class CViewUp : public CViewclass CViewDown : public CView2,在这两个类的头文件中添加宏声明:DECLARE_DYNCREATE(CViewUp)DECLARE_DYNCREATE(CViewDown )在这两个类的实现文件中添加宏实现(定义):IMPLEMENT_DYNCREATE(CViewUp, CView)IMPLEMENT_DYNCREATE(CViewDown , CView)(注: 不要直接粘贴这里的代码,你应该在英文格式下输入上述代码)


声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,谢谢。

上一篇: stimulated(stimulate怎么读)

下一篇: 女生害怕结婚的原因,女朋友害怕结婚是什么原因(现代女性恐婚恐孕的真实原因)



推荐阅读

网站内容来自网络,如有侵权请联系我们,立即删除! | 软文发布 | 粤ICP备2021106084号