You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
cereal is a header-only C++11 serialization library. cereal takes arbitrary data types and reversibly turns them into different representations, such as compact binary encodings, XML, or JSON. cereal was designed to be fast, light-weight, and easy to extend - it has no external dependencies and can be easily bundled with other code or used standalone.
cereal has great documentation
Looking for more information on how cereal works and its documentation? Visit cereal's web page to get the latest information.
cereal is easy to use
Installation and use of of cereal is fully documented on the main web page, but this is a quick and dirty version:
Download cereal and place the headers somewhere your code can see them
Write serialization functions for your custom types or use the built in support for the standard library cereal provides
Use the serialization archives to load and save data
#include<cereal/types/unordered_map.hpp>
#include<cereal/types/memory.hpp>
#include<cereal/archives/binary.hpp>
#include<fstream>structMyRecord
{
uint8_t x, y;
float z;
template <classArchive>
voidserialize( Archive & ar )
{
ar( x, y, z );
}
};
structSomeData
{
int32_t id;
std::shared_ptr<std::unordered_map<uint32_t, MyRecord>> data;
template <classArchive>
voidsave( Archive & ar ) const
{
ar( data );
}
template <classArchive>
voidload( Archive & ar )
{
staticint32_t idGen = 0;
id = idGen++;
ar( data );
}
};
intmain()
{
std::ofstream os("out.cereal", std::ios::binary);
cereal::BinaryOutputArchive archive( os );
SomeData myData;
archive( myData );
return0;
}