MFC对可Serialize类型的版本控制

本文介绍了如何利用MFC的版本控制功能处理可Serializable类型在软件升级后的序列化/反序列化问题。通过使用IMPLEMENT_SERIAL宏并设置VERSIONABLE_SCHEMA标志,可以避免因模式号不匹配引发的异常。在反序列化时,通过GetObjectSchema获取文件模式号,并根据版本执行不同的加载逻辑。此外,还提到了在模式号不能解决问题时,可以考虑根据文件扩展名或使用版本升级工具作为替代解决方案。
摘要由CSDN通过智能技术生成

使用MFC提供的Serialize功能对类型进行序列化/反序列化非常的方便。当软件升级后,Serialize的内容可能也会发生变化,这时,就可以使用MFC提供的版本控制功能解决反序列化因为内容不同引起的冲突了。

编写可序列化类时,MFC用IMPLEMENT_SERIAL宏指定的模式号作为版本控制的依据。反序列化时,MFC将文件中记录的模式号与应用程序中使用的模式号进行对比,如果不匹配,MFC将抛出一个CArchiveException异常,其m_cause等于CArchiveException::badSchema。为了避免产生异常,我们需要在指定新模式号的同时使用VERSIONABLE_SCHEMA标志,如下所示:

IMPLEMENT_SERIAL(XX, XXX, 2 | VERSIONABLE_SCHEMA)    //假设升级前的模式号是1

这样,在Serialize函数内就可以通过GetObjectSchema函数获得反序列化文件的模式号了,如下所示:
void XX::Serialize(CArchive& ar)
{
    //Call base's Serialize method.

    if(ar.IsStoring())
    {
         //Save value to ar.
    }else
    {
         UINT ver = ar.GetObjectSchema();
         switch(ver)
         {
              case 1:
                    //Load old version value.
              break;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值