请输入您要查询的百科知识:

 

词条 CRuntimeClass
释义

CRuntimeClass没有基类。 每个由CObject派生的类都与一个CRuntimeClass结构相联系,用户可以使用该结构获取一个对象及其基类的运行时信息。当需要额外的函数参数检查时,或当用户必须根据一个对象的类编写特殊目的代码时,在运行时确定该对象的类就非常有用。C++并不直接支持运行时类的信息。

CRuntimeCla

此结构具有下列

成员

LPCSTR m_lpszClassName 存放ASCII类名的以空字符结尾的字符串。

int m_nObjectSize

以字节为单位给出对象的大小。若此对象具有指向被分配的内存的数据成员,则此值不包含该内存的大小。

UINT m_wSchema

分类编号(对不可分类的类,该值为-1)。对于此分类编号的详细说明,参见IMPLEMENT_SERIAL宏。

CObject* ( PASCAL* m_pfnCreateObject )( )

是一个指向缺省的构造函数的函数指针,该构造函数创建一个你的类的对象(只有在类支持动态创建时才有效;否则,返回NULL)。

CRuntimeClass* ( PASCAL* m_pfn_GetBaseClass )( )

如果你的应用程序是动态地链接到MFC的AFXDLL版本,则是一个指向函数的指针,该函数返回基类的CRuntimeClass结构。

CRuntimeClass* m_pBaseClass

如果你的应用程序是静态地链接到MFC的,则是一个指向基类的CRuntimeClass结构的指针。

Feature Only in Professional and Enterprise Editions 只有在Visual C++的专业版和企业版中才支持对MFC的静态链接。

CObject* CreateObject( );

从CObject派生的类可以支持动态创建,这是在运行时创建一个指定类的对象的能力。例如,文档,视和框架类就应该支持动态创建。CreateObject成员函数可以用来实现这个功能,在运行时为这些类创建对象。

BOOL IsDerivedFrom( const CRuntimeClass* pBaseClass) const;

如果IsDerivedFrom类成员的类是从基类派生而来,该基类的CRuntimeClass结构作为一个参数给出,则返回TRUE。IsDerivedFrom从该成员的类开始向上沿派生类链经过所有的类直到顶端,并且只有在没有与基类匹配的类时才返回FALSE。

注意

要使用CRuntimeClass结构,你必须在你想要获取运行时对象信息的类的实现中包括IMPLEMENT_DYNAMIC,IMPLEMENT_DYNCREATE,或IMPLEMENT_SERIAL宏。

请参阅:

CObject::GetRuntimeClass, CObject::IsKindOf, RUNTIME_CLASS, IMPLEMENT_DYNAMIC, IMPLEMENT_DYNCREATE, IMPLEMENT_SERIALCRuntimeClass在MFC中的作用很重要,因为MFC利用它来进行类的动态确定,即是通过类变量来判定该变量是否为某一类的实例。由于指针的类型是可以转换的,所以时常会出现从A到B的转换导致错误。而在MFC的各种书籍中对CRuntimeClass的介绍是比较少的,在这里总结它的一些用法。

1、动态确定类

在MFC中CObject::IsKindOf( const CRuntimeClass* pClass ) 利用CRuntimeClass来进行判定,如果你生成的类是以CObject为基础的,你可以使用该成员函数来判定。下面举一个例子来加深了解。

class CAge:public CObject

BOOL IsAge(CObject* pO)

{

return pO->IsKindOf( RUNTIME_CLASS( CAge ) );

}

BOOL IsAge2(CAge* pO)

{

return pO->IsKindOf( RUNTIME_CLASS( CAge ) );

}

void main(void)

{

CObject a;

CAge b;

IsAge(&a);//return FALSE

IsAge(&b);//return TRUE

IsAge2((CAge*)&a);//return FALSE,避免强制转换带来的错误

}

2、生成类

CObject CRuntimeClass::CreateObject(void)可以产生一个类变量。作用和new类似,但在某些特殊场合有独特的作用。下面举一个例子来加深了解。

假定有以下几个类定义

class CWndA: public CWnd

class CWndB: public CWnd

function1()

{

CRuntimeClass* pC=RUNTIME_CLASS( CWndA );

CreateWnd(pC);

}

CWnd* CreateWnd(CRuntimeClass* pClass)

{

return (CWnd*)pClass->CreateObject();

}

在上面例子中,CreateWnd返回的是CWnd* 其实它是一个CWndA*。你可以进行由父类到子类的强制转换而不必要担心出错。使用CRuntimeClass可以代替使用switch生产类实例的一些繁琐。(请好好想想它的用途,当你发现它的好处时,你一定会大吃一惊,M$使用宏来实现类的动态检测,如果谁有兴趣可以去看看MFC的源代码。)

注意:在类的定义中使用IMPLEMENT_DYNCREATE后方可生效。

随便看

 

百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。

 

Copyright © 2004-2023 Cnenc.net All Rights Reserved
更新时间:2024/12/23 5:14:05