我想序列化一个包含 boost::multiprecision::mpfr_float 作为成员的自定义类。它在 Boost.Serialization 文档中说T
,如果 5 个属性中的至少一个为真,则类型是可序列化的,而在Multiprecision 文档中,number
该类具有传递支持,这需要底层后端可序列化。
对于 Boost.Multiprecision 的mpfr_float
类型,我知道:
- 它不是原始类型。
- 它是一个类类型,但它没有
serialize
定义函数。 - 它不是指向 Serializable 类型的指针。
- 它不是对 Serializable 类型的引用。
- 它不是 Serializable 类型的本机 C++ 数组。
因此,看起来如果我想序列化 mpfr_float 类型,我必须为该类型提供serialize
函数。
我的问题是:如何mpfr_float
通过自己编写serialize
函数将类型扩展为可序列化?我想我需要访问 mpfr 后端,并使用底层数据,但我不确定如何继续。来自有经验的人的提示 Boost 序列化以前未序列化的类将不胜感激。
结论性解决方案
根据 sehe 的回复,我得出了一个解决方案,该解决方案可以以 100 和 1000 的精度进行往返:
namespace boost { namespace serialization { // insert this code to the appropriate namespaces
/**
Save a mpfr_float type to a boost archive.
*/
template <typename Archive>
void save(Archive& ar, ::boost::multiprecision::backends::mpfr_float_backend<0> const& r, unsigned /*version*/)
{
std::string tmp = r.str(0, std::ios::fixed);// 0 indicates use full precision
ar & tmp;
}
/**
Load a mpfr_float type from a boost archive.
*/
template <typename Archive>
void load(Archive& ar, ::boost::multiprecision::backends::mpfr_float_backend<0>& r, unsigned /*version*/)
{
std::string tmp;
ar & tmp;
r = tmp.c_str();
}
} } // re: namespaces
该方案解决了上述第(2)项的需要,即需要添加serialize
功能。谢谢您的帮助。