基于标题,我编写了以下标题,它允许对进程间向量进行序列化。更多细节可以在我的 github repo中找到。
问候马库斯
#ifndef SHMFW_SERIALIZATION_INTERPROCESS_VECTOR_HPP
#define SHMFW_SERIALIZATION_INTERPROCESS_VECTOR_HPP
#include <boost/serialization/vector.hpp>
#include <boost/interprocess/containers/vector.hpp>
namespace boost {
namespace serialization {
template<class Archive, class U, class Allocator>
inline void save(
Archive & ar,
const boost::interprocess::vector<U, Allocator> &t,
const unsigned int file_version
){
boost::serialization::stl::save_collection<Archive, boost::interprocess::vector<U, Allocator> >(
ar, t
);
}
template<class Archive, class U, class Allocator>
inline void load(
Archive & ar,
boost::interprocess::vector<U, Allocator> &t,
const unsigned int file_version
){
#ifdef BOOST_SERIALIZATION_VECTOR_135_HPP
if (ar.get_library_version()==boost::archive::library_version_type(5))
{
load(ar,t,file_version, boost::is_arithmetic<U>());
return;
}
#endif
boost::serialization::stl::load_collection<
Archive,
boost::interprocess::vector<U, Allocator>,
boost::serialization::stl::archive_input_seq<
Archive, boost::interprocess::vector<U, Allocator>
>,
boost::serialization::stl::reserve_imp<boost::interprocess::vector<U, Allocator> >
>(ar, t);
}
// split non-intrusive serialization function member into separate
// non intrusive save/load member functions
template<class Archive, class U, class Allocator>
inline void serialize(
Archive & ar,
boost::interprocess::vector<U, Allocator> & t,
const unsigned int file_version
){
boost::serialization::split_free(ar, t, file_version);
}
#if ! BOOST_WORKAROUND(BOOST_MSVC, <= 1300)
/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8
// vector<bool>
template<class Archive, class Allocator>
inline void save(
Archive & ar,
const boost::interprocess::vector<bool, Allocator> &t,
const unsigned int /* file_version */
){
// record number of elements
collection_size_type count (t.size());
ar << BOOST_SERIALIZATION_NVP(count);
boost::interprocess::vector<bool>::const_iterator it = t.begin();
while(count-- > 0){
bool tb = *it++;
ar << boost::serialization::make_nvp("item", tb);
}
}
template<class Archive, class Allocator>
inline void load(
Archive & ar,
boost::interprocess::vector<bool, Allocator> &t,
const unsigned int /* file_version */
){
// retrieve number of elements
collection_size_type count;
ar >> BOOST_SERIALIZATION_NVP(count);
t.clear();
while(count-- > 0){
bool i;
ar >> boost::serialization::make_nvp("item", i);
t.push_back(i);
}
}
// split non-intrusive serialization function member into separate
// non intrusive save/load member functions
template<class Archive, class Allocator>
inline void serialize(
Archive & ar,
boost::interprocess::vector<bool, Allocator> & t,
const unsigned int file_version
){
boost::serialization::split_free(ar, t, file_version);
}
#endif // BOOST_WORKAROUND
};
};
#endif // SHMFW_SERIALIZATION_INTERPROCESS_VECTOR_HPP