Learning boost 1 Serialization

Learning boost (1)

Serialization

简单的开始

Serialization的中文解释是“串行化” 、“序列化”或者“持久化” ,就是将内存中的对象保存到磁盘中,等到程序再次运行的时候再读取磁盘中的文件恢复原来的对象。下面来看一个简单的例子:

#include <fstream>

#include <iostream>

#include <boost/archive/text_oarchive.hpp>

#include <boost/archive/text_iarchive.hpp>

class A

{

private:

    //为了能让串行化类库能够访问私有成员,所以要声明一个友元类

    friend class boost::serialization::access;

    //对象的数据

    int a;

    double b;

    //串行化的函数,这一个函数完成对象的保存与恢复

    template<class Archive>

    void serialize(Archive & ar, const unsigned int version)

    {

        ar & a;   //就是这么简单,也可以使用 ar<<a 这样的语法

        ar & b;

    }

public:

    A(int aa,double bb):a(aa),b(bb){}

    A(){}

    void print(){std::cout<<a<<' '<<b<<std::endl;}

};   

int main()

{

   std::ofstream fout("file.txt");//把对象写到file.txt文件中

   boost::archive::text_oarchive oa(fout);//文本的输出归档类,使用一个ostream来构造

   A obj(1,2.5);

   oa<<obj;//保存obj对象

   fout.close();//关闭文件

  

   std::ifstream fin("file.txt");

   boost::archive::text_iarchive ia(fin);//文本的输入归档类

   A newobj;

   ia>>newobj;//恢复到newobj对象

   newobj.print();

   fin.close();

   system("pause");

   return 0;

}

 

从上面可以看出,boost是使用text_oarchivetext_iarchive 类,来完成一个对象的序列化的。使用这两个类的步骤是:

1.      在源程序中包含boost/archive/text_oarchive.hpp boost/archive/text_iarchive.hpp 这两个文件。

2.      为需要序列化的类添加一个template<class Archive> void serialize(Archive & ar, const unsigned int version)的模版成员函数。

3.      如果需要对象中包含私有成员的话,需要把boost::serialization::access类声明为友元。

4.      在主函数中,创建一个输出文件流对象, 使用这个对象构造一个text_oarchive对象,然后就可以使用<<操作符来输出对象了。

5.      最后,同样的,使用text_iarchive来恢复对象。

 

继承

如果要序列化一个子类的话,方法是不同的。例:

#include <boost/serialization/base_object.hpp>  //一定要包含此头文件

class B:A

{

    friend class boost::serialization::access;

    char c;

    template<class Archive>

    void serialize(Archive & ar, const unsigned int version)

    {

        ar & boost::serialization::base_object<A>(*this);//注意这里

        ar & c;

    }

public:

    ...

};   

 

对子类进行序列化的步骤是:

1.      包含boost/serialization/base_object.hpp头文件

2.      serialize模版函数中,使用ar & boost::serialization::base_object<父类>(*this)这样的语法来保存父类的数据,不能直接调用父类的serialize函数

 

STL容器

如果要序列化一个STL容器,要使用boost自带的头文件,不能直接#include<vector>

例如:

#include <boost/serialization/list.hpp>// Serialization中特定的头文件,list.hpp中已经包含了stllist头文件

Class A

{

  ...

  list<int> list;

template<class Archive>

void serialize(Archive & ar, const unsigned int version)

  {

      ar & list;

  }

...

}

Serialization中,类似的头文件还有vector.hpp string.hpp set.hpp map.hpp slist.hpp等等。

 

数组和指针

对于数组和指针可以直接序列化,例:

Class A

{

  ...

  int a[10];

  int *b

template<class Archive>

void serialize(Archive & ar, const unsigned int version)

  {

      ar & a;

      ar & b;

  }

...

}

 

其他的archive

除了text_iarchivetext_oarchive之外,还有其他的archive类,可以把对象保存成不同格式的文件。

// a portable text archive

boost::archive::text_oarchive(ostream &s) // saving

boost::archive::text_iarchive(istream &s) // loading

 

// a portable text archive using a wide character stream

boost::archive::text_woarchive(wostream &s) // saving

boost::archive::text_wiarchive(wistream &s) // loading

 

// a non-portable native binary archive

boost::archive::binary_oarchive(ostream &s) // saving

boost::archive::binary_iarchive(istream &s) // loading

 

// a portable XML archive

boost::archive::xml_oarchive(ostream &s) // saving

boost::archive::xml_iarchive(istream &s) // loading

 

// a portable XML archive which uses wide characters - use for utf-8 output

boost::archive::xml_woarchive(wostream &s) // saving

boost::archive::xml_wiarchive(wistream &s) // loading

 

 

### 安装 Boost.Serialization 库 为了成功安装并配置 `Boost.Serialization` 库,需遵循一系列特定的操作指南来确保库能被正确识别和链接到项目中。 #### 下载与解压 Boost 源码包 首先访问官方Boost网站下载最新版本的源代码压缩包。完成下载之后将其解压缩至本地磁盘上的合适位置[^3]。 #### 配置环境变量 对于Windows操作系统而言,在Visual Studio环境中开发的话,则应该把Boost根目录以及包含二进制文件子目录路径加入如下设置项:“C/C++ > Additional Include Directory” 和 “Linker > Additional Library Directories”。这一步骤是为了让编译器知道去哪里寻找头文件及静态/动态链接库。 #### 构建过程中的注意事项 构建过程中需要注意一些细节问题以避免潜在障碍。例如,在某些情况下可能会遇到由于存在特殊命名模式(* copy.hpp) 的多余文件而导致复制操作失败的情况;此时可以通过手动删除这些不必要的文件解决此问题[^4]。 #### 使用 b2 工具进行自定义安装 通过命令行进入已解压好的Boost主文件夹内运行bootstrap.bat脚本初始化构建工具链。接着可以利用b2指令加上适当参数如`--prefix=指定安装路径 --with-serialization` 来执行定制化安装流程[^1]。 ```bash .\bootstrap.bat .\b2 --prefix=C:\local\boost_1_70_0 --with-serialization install ``` #### 测试安装是否成功 创建一个简单的测试程序验证能否正常调用Serialization功能模块: ```cpp #include <iostream> #include <fstream> #include <boost/archive/text_oarchive.hpp> struct Test { int value; template<class Archive> void serialize(Archive & ar, const unsigned int version){ ar & value; } }; int main(){ std::ofstream ofs("test.txt"); boost::archive::text_oarchive oa(ofs); Test t{42}; oa << t; return 0; } ``` 上述代码尝试将结构体实例序列化保存成文本格式的数据流,并写入名为 "test.txt" 文件中去。如果一切顺利则说明已经完成了Boost.Serialization库的成功部署。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值