Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1614381
  • 博文数量: 441
  • 博客积分: 20087
  • 博客等级: 上将
  • 技术积分: 3562
  • 用 户 组: 普通用户
  • 注册时间: 2006-06-19 15:35
文章分类

全部博文(441)

文章存档

2014年(1)

2012年(1)

2011年(8)

2010年(16)

2009年(15)

2008年(152)

2007年(178)

2006年(70)

分类: C/C++

2006-11-29 10:32:06

    如果一个对象支持串行化,那么它一定是可串行化的实例。编写可串行化的一般步骤:
    (1)直接或间接得到CObject的派生类
    (2)在类的说明文件中加入DECLARE_SERIAL宏,格式如下:
         DECLARE_SERIAL(Class_Name)
    (3)重载基类的Serialize函数,并串行化派生类的数据成员
    (4)如果派生类没有默认的构造函数(无参数)则添加一个。因为对象并行化时,mfc要用默认的构造函数在浮动标签上创建对象,并用从文档取回的值设置对象数据成员的初始值,这一步是非常必要的。
    (5)在类的实现中加入IMPLEMENT_SERIAL(类名,基类名,模式号)宏。模式号是一个整形值,等于版本号。只要修改了类的串行化数据格式,模式号也要改变。

    下面看一个例子,CLine类,该类有两个数据成员,它们存储线的两个端点。类的初始声明如下:

class CLine
{
protected:
    CPoint m_ptFrom;
    CPoint m_ptTo;
public:
    CLine(CPoint ptFrom, CPoint ptTo){m_ptFrom = ptFrom; m_ptTo = ptTo;}
};

将改类添加串行化支持:

class CLine:public CObject  //添加基类支持
{
DECLARE_SERIAL(CLine)

protected:
    CPoint m_ptFrom;
    CPoint m_ptTo;

public:
    CLine(){} //添加默认构造函数,必须的
    CLine(CPoint ptFrom, CPoint ptTo){m_ptFrom = ptFrom; m_ptTo = ptTo;}
    void Serialize(CArchive& ar); // 重载基类的Serialize虚拟函数
};

在类的实现中

IMPLEMENT_SERIAL(CLine, CObject, 1)

void CLine::Serialize(CArchive& ar)
{
    CObject::Serialize(ar);

    if ( ar.IsStoring() ) // Store
    {
       ar << m_ptFrom << m_ptTo;
    }
    else  // Load
    {
       ar >> m_ptFrom >> m_ptTo;
    }
}
       
阅读(1084) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~