您的位置首页百科问答

DECLARE_SERIAL的概念

DECLARE_SERIAL的概念

的有关信息介绍如下:

DECLARE_SERIAL / IMPLEMENT_SERIAL 宏的技术详解(转) DECLARE_DYNAMIC表明的是支持类型信息, 有了这个宏,我们就可以判断一个类究竟是什么类,比如

class A;

class B:public A;

A a;

B b;

有一个指针 class *pA 它指向一个对象, 请问你怎么知道pA指向的是a对象还是b对象,这时如果有类型信息,我们就可以知道pA到底是什么对象, 其实,它内部的实现原理是一个字符串,所以,进行这个判断时,实际上是字符串比较.

DECLARE_DYNCREATE是动态创建的意思.这个有点类似Com的类工厂.

它实际祥孙上是用类CRunTime class记录了类的静态创建函数的地址.这个特性在很多地方需要使用.就在下面说的DECLARE_SERIAL就是一个经典的例子.

动态创建主要用在 我不知道要创建的对象就是是什么类,但是我知道它肯定是从某个基类派生的.

DECLARE_SERIAL是指序列化特性,它是一个完全自动化的存储机制,它可以将一个对象数组(可能含有A,B,C类的对象)存储进去,而且能够根据存储的情况准确的载入进来,这看起来很简单, 但是,有一个问题我们必须考虑, 就是怎么写这个程序,使得载入的时候能够正确创建相应的A,B,C类的对象呢(注意,这里是三个不同的类).而且MFC的设计人员当初编写这个机制的时候根本不知道到底会出现什么类,也许还会出现D类. 怎谨知链么办呢?

可以肯定,存储机制中必须要有能够判断类种类的代码.所以,序列化机制DECLARE_SERIAL包含了DECLARE_DYNAMIC,这样在存储进入文件的时候,可以将类名称存储到文件中.

OK,我们载入的时候可以知道我们要载入什么类了,但是,我们又要怎么去创建它呢? 所以DECLARE_SERIAL也包含了DECLARE_DYNCREATE,它用于创建对象.

那么,DECLARE_SERIAL到底有什么特殊的地方呢?首先,它必须实现operator>>(具体原因可以看看深入浅出,还有版本控制,这样,我们在处理序列化时,可以很灵活.

首先记住一点,DECLARE_SERIAL最主要的用途是一种智能存储.所以我们可以不用这个智能特性.

当我们没有DECLARE_SERIAL,而有void CMessg::Serialize(CArchive& ar)时,我们只能这样进行存储

CDocument::Serialize(ar)

{

if (ar.isstoring())

{

//存储一个对象

pMessg->Serialize(ar);

}

else

{

//必须非常明确的指出New一个 CMessg对象;

pMessg = new CMessg;

pMessg->Serialize(ar);

}

}

在上面这个例子中,根本没有利用MFC为我们设计的序列化只能机制.

再看下面一个例子

CDocument::Serialize(ar)

{

if (ar.isstoring())

{

//存储一个对象

ar <<猛宽 pMessg;

}

else

{

//必须非常明确的指出New一个 CMessg对象;

ASSERT(pMessg == NULL);

ar >> pMessg;

}

}

DECLARE_SERIAL的概念