文档详情

windows编程.doc

发布:2017-02-02约9.68千字共11页下载文档
文本预览下载声明
一、线性化函数(串行化函数)------CObject::Serialize 功能: 从档案文件中读取该对象或者向档案文件中写入该对象 必须为希望串行化的每个类重载Serialize函数,被重载的Serialize函数首先必须调用基类的Serialize函数。在类的声明中必须使用DECLARE_SERYAL宏,并且在类的执行过程中必须使用IMPLEMENT_SERIAL宏 IMPLEMENT_SERIAL 二、IMPLEMENT_SERIAL( class_name, base_class_name, wSchema ) 参数: class_name 类的实际名字(不用引号括起来)。 base_class_name 基类的名字(不用引号括起来)。 wSchema 一个UINT类型的版本号,将被用在存档中,使得解串行程序能够识别并处理早期版本的程序所生成的数据。它的值不能是-1。 说明: 这个宏为动态的CObject派生类对象生成必要的C++代码,使它能够在运行时访问类名及其在继承关系中的位置。在.CPP模块中使用IMPLEMENT_SERIAL宏,然后一次性地连接生成的目标代码。果磁盘文件上的对象的版本号和内存中的对象的版本号不一致,MFC将抛出一个CArchiveException异常,阻止程序读入一个不匹配版本的对象。. 从CObject或其派生类派生出用户的类 2. 重载Serialize()成员函数,加入必要的代码,用以保存对象的数据成员到CArchive对象以及从CArchive对象载入对象的数据成员状态。 3. 在类声明文件中,加入DECLARE_SERIAL宏。编译时,编译器将扩充该宏,这是串行化对象所必需的。 4. 定义一个不带参数的构造函数。 5. 在实现文件中加入IMPLEMENT_SERIAL宏。 class CRegister:public CObject { public: DECLARE_SERIAL( CRegister) // 必需提供一个不带任何参数的空的构造函数 CRegister(){};   public: CString strIncome; CString strKind; BOOL bMarried; CString strName; int nSex; CString strUnit; int nWork; UINT nAge; void Serialize(CArchive); }; MFC在从磁盘文件载入对象状态并重建对象时,需要有一个缺省的不带任何参数的构造函数。串行化对象将用该构造函数生成一个对象,然后调用Serialize()函数,用重建对象所需的值来填充对象的所有数据成员变量。 构造函数可以声明为public、protected或private。如果使它成为protect或private,则可以确保它只被串行化过程所使用。 在类定义文件中给出Serialize()的定义。它包括对象的保存和载入两部分。前面已经提到,CArchive类提供一个IsStoring()成员函数指示是保存数据到磁盘文件还是从磁盘文件载入对象。 void CRegister::Serialize(CArchive ar) { // 首先调用基类的Serialize()方法。 CObject::Serialize( ar); if(ar.IsStoring()) { arstrIncome; arstrKind; ar(int)bMarried; arstrName; arnSez; arstrUnit; arnWork; ar(WORD)nAge; } else { arstrIncome; arstrKind; ar(int)bMarried; arstrName; arnSex; arstrUnit; arnWork; ar(WORD)nAge; } } 我们看到,对象的串行化实际上是通过调用对象中的数据成员的串行化来完成的。 注意:CArchive类的和操作符并不支持所有的标准数据类型。它支持的数据类型有:CObject、BYTE、WORD、int、LONG、DWORD、float和double。其他的类型的数据要进行串行化输入输出时,需要将该类型的数据转化为上述几种类型之一方可。 另外,在类的实现(类定义)文件开始处,还要加入IMPLEMENT_SERIAL宏。 IMPLEMENT_SERIAL( CRegister, CObject, 1 ) IMPLEMENT_SERIAL宏用于定义一个从CObject派生的可串行化类的各种函数。宏的第一和第二个参数分
显示全部
相似文档