• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            簡單的開始
            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
             
             
            posted on 2010-06-05 17:52 會飛的兔子 閱讀(2338) 評論(0)  編輯 收藏 引用 所屬分類: C++庫,組件
            99久久99久久久精品齐齐| 欧洲成人午夜精品无码区久久| 久久久久人妻一区二区三区| 久久香蕉国产线看观看99| 蜜臀久久99精品久久久久久小说| 久久久久国产| 久久久久女教师免费一区| 爱做久久久久久| 久久精品夜色噜噜亚洲A∨| 狠狠精品久久久无码中文字幕| 国产日韩久久免费影院| 9191精品国产免费久久| 激情综合色综合久久综合| 久久中文字幕无码专区| 午夜精品久久久久| 亚洲精品乱码久久久久久蜜桃图片| 久久精品亚洲AV久久久无码| 国内精品久久久久久久久电影网| 亚洲中文字幕无码一久久区| 久久天堂AV综合合色蜜桃网| 99久久免费国产精品热| 久久99精品国产麻豆蜜芽| 色偷偷91久久综合噜噜噜噜| 亚洲成色WWW久久网站| 久久免费高清视频| 亚洲国产成人久久综合区| 青草国产精品久久久久久| 国产成人精品综合久久久| 日日狠狠久久偷偷色综合免费| 亚洲午夜久久久影院| 久久久久国产精品| 欧美精品九九99久久在观看| 久久久av波多野一区二区| 国产精品久久久久乳精品爆| 久久人妻少妇嫩草AV蜜桃| 国产一级持黄大片99久久| 久久99热这里只有精品66| 国产69精品久久久久777| 精品熟女少妇AV免费久久| 精品多毛少妇人妻AV免费久久| 久久精品国产亚洲AV麻豆网站 |