Is it safe to serialize a raw boost::variant?(序列化原始 boost::variant 是否安全?)
问题描述
boost::variant 声称它是一种值类型.这是否意味着简单地写出 boost::variant 的原始表示并稍后加载它是安全的,只要它只包含 POD 类型?假设它将由相同编译器和相同版本的 boost 编译的代码在相同的架构上重新加载.
boost::variant claims that it is a value type. Does this mean that it's safe to simply write out the raw representation of a boost::variant and load it back later, as long as it only contains POD types? Assume that it will be reloaded by code compiled by the same compiler, and same version of boost, on the same architecture.
另外,(可能)等价地,boost::variant 可以用在共享内存中吗?
Also, (probably) equivalently, can boost::variant be used in shared memory?
推荐答案
关于序列化:它应该有效,是的.但是为什么不使用boost::variant
的访问机制来写出variant中包含的实际类型呢?
Regarding serialisation: It should work, yes. But why don't you use boost::variant
's visitation mechanism to write out the actual type contained in the variant?
struct variant_serializer : boost::static_visitor<void> {
template <typename T>
typename boost::enable_if< boost::is_pod<T>, void>::type
operator()( const T & t ) const {
// ... serialize here, e.g.
std::cout << t;
}
};
int main() {
const boost::variant<int,char,float,double> v( '1' );
variant_serializer s;
boost::apply_visitor( s, v );
return 0;
}
关于共享内存:boost::variant
不执行堆分配,所以你可以像 int
一样将它放入共享内存,当然,假设适当的同步.
Regarding shared memory: boost::variant
does not perform heap allocations, so you can place it into shared memory just like an int
, assuming proper synchronisation, of course.
不用说,正如您所说,以上仅当变体只能包含 POD 类型时才有效.
Needless to say, as you said, the above is only valid if the variant can only contain POD types.
这篇关于序列化原始 boost::variant 是否安全?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:序列化原始 boost::variant 是否安全?
基础教程推荐
- 使用从字符串中提取的参数调用函数 2022-01-01
- 为什么语句不能出现在命名空间范围内? 2021-01-01
- 如何使图像调整大小以在 Qt 中缩放? 2021-01-01
- 为 C/C++ 中的项目的 makefile 生成依赖项 2022-01-01
- 如何“在 Finder 中显示"或“在资源管理器中显 2021-01-01
- 在 C++ 中循环遍历所有 Lua 全局变量 2021-01-01
- 管理共享内存应该分配多少内存?(助推) 2022-12-07
- 如何在不破坏 vtbl 的情况下做相当于 memset(this, ...) 的操作? 2022-01-01
- Windows Media Foundation 录制音频 2021-01-01
- 从 std::cin 读取密码 2021-01-01