天天看點

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