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_oarchive和text_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中已經包含了stl的list頭文件
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_iarchive和text_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
 
 

 
發佈了3 篇原創文章 · 獲贊 1 · 訪問量 15萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章