⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 serialization.cpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 CPP
字号:
/* Boost.MultiIndex example of serialization of a MRU list. * * Copyright 2003-2008 Joaquin M Lopez Munoz. * Distributed under the Boost Software License, Version 1.0. * (See accompanying file LICENSE_1_0.txt or copy at * http://www.boost.org/LICENSE_1_0.txt) * * See http://www.boost.org/libs/multi_index for library home page. */#if !defined(NDEBUG)#define BOOST_MULTI_INDEX_ENABLE_INVARIANT_CHECKING#define BOOST_MULTI_INDEX_ENABLE_SAFE_MODE#endif#include <boost/config.hpp> /* keep it first to prevent nasty warns in MSVC */#include <algorithm>#include <boost/archive/text_oarchive.hpp>#include <boost/archive/text_iarchive.hpp>#include <boost/multi_index_container.hpp>#include <boost/multi_index/hashed_index.hpp>#include <boost/multi_index/identity.hpp>#include <boost/multi_index/sequenced_index.hpp>#include <fstream>#include <iostream>#include <iterator>#include <sstream>#include <string>using namespace boost::multi_index;/* An MRU (most recently used) list keeps record of the last n * inserted items, listing first the newer ones. Care has to be * taken when a duplicate item is inserted: instead of letting it * appear twice, the MRU list relocates it to the first position. */template <typename Item>class mru_list{  typedef multi_index_container<    Item,    indexed_by<      sequenced<>,      hashed_unique<identity<Item> >    >  > item_list;public:  typedef Item                         item_type;  typedef typename item_list::iterator iterator;  mru_list(std::size_t max_num_items_):max_num_items(max_num_items_){}  void insert(const item_type& item)  {    std::pair<iterator,bool> p=il.push_front(item);    if(!p.second){                     /* duplicate item */      il.relocate(il.begin(),p.first); /* put in front */    }    else if(il.size()>max_num_items){  /* keep the length <= max_num_items */      il.pop_back();    }  }  iterator begin(){return il.begin();}  iterator end(){return il.end();}  /* Utilities to save and load the MRU list, internally   * based on Boost.Serialization.   */  void save_to_file(const char* file_name)const  {    std::ofstream ofs(file_name);    boost::archive::text_oarchive oa(ofs);    oa<<boost::serialization::make_nvp("mru",*this);  }  void load_from_file(const char* file_name)  {    std::ifstream ifs(file_name);    if(ifs){      boost::archive::text_iarchive ia(ifs);      ia>>boost::serialization::make_nvp("mru",*this);    }  }private:  item_list   il;  std::size_t max_num_items;  /* serialization support */  friend class boost::serialization::access;      template<class Archive>  void serialize(Archive& ar,const unsigned int)  {    ar&BOOST_SERIALIZATION_NVP(il);    ar&BOOST_SERIALIZATION_NVP(max_num_items);  }};int main(){  const char* mru_store="mru_store";  /* Construct a MRU limited to 10 items and retrieve its   * previous contents.   */  mru_list<std::string> mru(10);  mru.load_from_file(mru_store);  /* main loop */  for(;;){    std::cout<<"enter a term: ";    std::string line;    std::getline(std::cin,line);    if(line.empty())break;    std::string term;    std::istringstream iss(line);    iss>>term;    if(term.empty())break;    mru.insert(term);    std::cout<<"most recently entered terms:"<<std::endl;    std::copy(      mru.begin(),mru.end(),      std::ostream_iterator<std::string>(std::cout,"\n"));  }  /* persist the MRU list */  mru.save_to_file(mru_store);  return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -